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Ciao mamma, sono contento di essere arrivato uno! 

Eccomi dunque qui a dare il mio contribuito 
organizzativo alla rivista. Come spesso capita (non so a 
voi, ma al sottoscritto sì), quando affronto una attività 
che conosco poco e che ha una scadenza molto precìsa , 
vengo preso da una latente preoccupazione di non 

arrivare in tempo. 

Così parto subito in quarta cercando di mettere assieme 
subito quanto possibile per avere un po' di respiro e 
avere più tempo per dedicarmi alle cose più sofisticate o 

delicate da mettere a punto. 
Così è stato con JN: non volendo m ancore la scadenza 
del V marzo per la data di pubblicazione, ho cominciato 
fin da novembre a lavorarci e infatti nelle prime 
settimane ero molto soddisfatto del punto dove ero 
arrivato. Poi gli impegni di lavoro e personali hanno avuto 
il sopravvento al punto che alla fine ci sono arrivato 
trafelato a confezionare questo fascicolo! 

Comunque è andata e devo dire che sono molto 
soddisfatto del risultato, anche perché gli amici mi 
hanno consegnato dei "pezzi" veramente al top! 
Il risultato è un fascicolo forse fra i più belli che 
abbiamo pubblicato, così almeno credo io, dall'alto della 

mia autostima :-) 

Un benvenuto caloroso aspetta ad un nuovo 
collaboratore: Giovanni, che siglerà i suoi pezzi con 
la firma jb72. Siamo molto felici di accogliere i suoi 
contributi alla causa comune della cultura retro¬ 
informatica! 

Sperando che anche voi condividiate il mio entusiasmo, vi 
auguro buon divertimento nella lettura e una bellissima 
primavera (è la mia stagione preferita). 

[Sonicher] 


Jurassic News 

è una fanzine 
dedicata al retro- 
computing nella più 
ampia accezione del 
termine. Gli articoli 
trattano in generale 
dell’informatica a 
partire dai primi anni 
‘80 e si spingono fino 
...all’altro ieri. 

La pubblicazione ha 
carattere puramente 
amatoriale e 
didattico, tutte 
le informazioni 
sono tratte da 
materiale originale 
dell’epoca o raccolte 
(e attentamente 
vagliate) da Internet. 

Normalmente il 
materiale originale, 
anche se “jurassico” 
in termini informatici, 
non è privo di 
restrizioni di utilizzo, 
pertanto non sempre 
è possibile riportare 
per intero articoli, 
foto, schemi, listati, 
etc..., che non siano 
esplicitamente liberi 
da diritti. 

La redazione e 
gli autori degli 
articoli non si 
assumono nessuna 
responsabilità 
in merito alla 
correttezza delle 
informazioni 
riportate o nei 
confronti di eventuali 
danni derivanti 
dall’applicazione di 
quanto appreso sulla 
rivista. 
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Retrocomputing 


La disponibilità di 
documentazione e le 
strategie di incremento 
e conservazione. 


La lunga marcia 

V orrei discutere in questo 
intervento della disponibi¬ 
lità della documentazione 
utile all’hobby del retrocomputing. 


Passando in rassegna la docu¬ 
mentazione che riguarda l’hobby 
del retrocomputing, notiamo esi¬ 
stere una variagata tipologia di 
documenti che ci sono utili se non 
addirittura indispensabili. 


Prima di tutto i manuali hardware 
e software corredati alle macchine, 
quando ancora questi avevano un 
senso; poi le riviste del settore, le 
monografie specifiche, le fanzine, 
i manuali a corredo di programmi 
e i listati stessi, commentati più o 
meno abbondantemente,... insom¬ 
ma una discreta varietà di oggetti 
che oggi sono sparsi un po’ dap¬ 
pertutto ma che non trovano pur¬ 
troppo una destinazione definitiva 
e globale. 


Grande plauso va fatto a tutte le 
iniziative che districandosi fra diritti 
e copyrights riescono a mettere in 
linea quanto possono. A volte si ha 
la fortuna di incappare in qualche 
ripensamento da parte degli editori 
che danno un provvisorio permes¬ 
so alla pubblicazione. 


Gli editori, per quanto male si 
possa dire di loro arroccati nelle 
posizioni in difesa di presunti diritti, 


non hanno proprio tutte le colpe. In 
realtà la legislatura italiana e inter¬ 
nazionale è piuttosto aggroviglia¬ 
ta sul tema di diritti d’autore e chi 
si azzarda a mettere on-line una 
qualsiasi cosa presa da un vecchio 
giornale o uno schema scanneriz- 
zato da un manuale, lo fa solita¬ 
mente a proprio rischio, pronto a 
cancellare il tutto alla prima lettera 
minatoria proveniente da presunti 
detentori di certi diritti che a volte 
non sappiamo bene decifrare. 

La reperibilità delle varie tipologie 
di documenti è diversificata, grazie 
anche alla diversa sensibilità che 
ne caratterizza la conservazione 
da parte dei possesori e alla nu¬ 
merosità che varia da tipologia a 
tipologia. 

Ad esempio i manuali a corredo 
delle macchine: non sono rari, si 
trovano anche in Internet quasi tut¬ 
ti, vuoi perché in fondo le machine 
costruite non sono milioni (intendo 
modelli diversi) e vuoi perché forse 
il manuale l’acquirente non è stato 
così stupido da liberarsene in quat¬ 
tro e quattrotto. 

Possono mancare nella versione 
italiana o in altro idioma, magari 
anche significativo, visto che non 
raramente lo stesso modello ve¬ 
niva venduto in paesi diversi con 
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qualche adattamento: il modulato¬ 
re TV, tanto per fare un esempio. 

Le monografie, cioè i libri scritti 
da autori indipendenti. Se ne sono 
prodotti a centinaia se non più, più 
o meno specifici, come ad esem¬ 
pio “Linguaggio macchina per ...” 
un classico! Questi hanno una vita 
più lunga perché un volume car¬ 
taceo ha una sorta di proprietà 
virtuale che gli si affibia appena 
prodotto: la gente è restia a but¬ 
tarlo. O meglio, esistono moltissi¬ 
me persone che si affezionano ai 
volumi che hanno comperato, non 
li prestano e meno che mai li ven¬ 
dono o peggio li bruciano. Trova¬ 
re questi “tesori”, ma anche solo 
titoli curiosi, è cosa di tutti i gior¬ 
ni se si frequentano le bancarelle 
dei remainder o i mercatini dei libri 
usati. 

Poi ci sono le biblioteche che rap¬ 
presentano una fonte spesso poco 
sfruttata dagli appasionati. Soprat¬ 
tutto le biblioteche specialistiche o 
universitarie sono una vera minie¬ 
ra di tesori da scoprire. Si acce¬ 
de al catalogo on-line, quello che 
in gergo si chiama OPAC (OPen 
Access Catalogue) e si cerca ad 
esempio “Apple”. Fra le centinaia 
di risultati ci saranno i trattati sulla 
coltivazione delle mele ma anche 
molti volumi dedicati ai computer 
della mela. In queste biblioteche, 
che consiglio senza alcun dubbio, 
ho trovato delle chicche che nem¬ 
meno sospettavo fossero state 
scritte! 

Le biblioteche a volte si rivelano 
anche contenitori di riviste. Qui le 


cose si fanno meno facili perché 
la tipologia “m agazi ne” o “periodi¬ 
co”, come si dice in Italia, ha degli 
svantaggi già al momento della 
produzione. Le riviste spesso ven¬ 
gono buttate perché invecchiano 
presto e occupano spazio sugli 
scaffali e questo anche nelle biblio¬ 
teche pubbliche, non solo in casa 
propria. Poi c’è il problema della 
completezza: quante volte abbia¬ 
mo visto o reperito intere collezio¬ 
ni di periodici alle quali, castigo di 
Dio, manca qualche numero? Che 
disdetta! Eh sì, perché il numero 
mancante “buca” la collezione che 
non si può dire così “completa”. Poi 
guarda caso è sempre sul numero 
che ci manca che ci sarebbe stato 
quel tale articolo, quella tale prova 
hardware, quella seconda puntata 
della guida alla quale avremmo te¬ 
nuto tanto,... 

La produzione di riviste nel set¬ 
tore computing è stata imponente, 
soprattutto dall’80 al 2000. Cer¬ 
cando on-line si trova qualche re- 
pository ben fornito, altri con pochi 
sparuti numeri e qualche coperti¬ 
na, altri ancora che promettono la 
scansione dei testi ma poi non se 
n’è fatto nulla... 

Da anni mi sto dedicando proprio 
a questa attività, assieme all’amico 
Sonicher: recuperare tutto il possi¬ 
bile di ciò che appare in Internet 
nel settore riviste per PC. E’ una 
strada lunga e forse che non ha 
una conclusione, ma come diceva 
il saggio: -"anche un lungo viaggio 
comincia con un piccolo passo”. 

[Tn] 
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Come era vamo... 


La storia dei 
sistemi e degli 
uomini che hanno 
creato un mondo 
nuovo. 


Installare Windows 3.1 



i ricordate i favolosi anni 
’80? Beh, favolosi per 
noi che ci occupavamo 
di informatica: tante cose da sco¬ 
prire, tante tecnologie annunciate, 
proposte, sperimentate. Il mondo 
stava diventando degli informatici, 
ci sentivamo Dio in Terra e infatti 
così è stato, cioè il mondo è degli 
informatici oggi, anche se siamo 
usati prevalentemente come com¬ 
primari, non come protagonisti. 
Per quanto riguarda la deità, que¬ 
sta è rimasta appannaggio del Dio 
Denaro. 

Vi ricordate la prima versione di 
Windows? Parlo della 1.0, uscita il 
20 novembre 1985 e arrivata in Ita¬ 
lia qualche mese più tardi, diciamo 


la primavera del 1986. Chi ha avu¬ 
to l’ardire di installarla (ammesso 
ci sia riuscito) sul suo clone IBM 
con 8088 e 512 Kb di RAM, se non 
ha vomitato subito probabilmente 
è stato solo perché s’è sbrigato a 
cancellare tutto chiedendo perdo¬ 
no al suo fedele, per quanto vitu¬ 
perato, DOS 3.0. 

Dopo questa prima uscita, le al¬ 
tre versioni: la 2.0, poi lo sdoppia¬ 
mento in 1286 e 1386 per cercare 
di sfruttare quel poco di più che i 
processori Intel di nuova concezio¬ 
ne potevano offrire. Le due versio¬ 
ni sono poi confluite nella versione 
3.0 del 22 maggio 1990. Ma non 
ci siamo ancora, bisognerà aspet¬ 
tare la release 3.1, codice segreto 
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“Janus”, peravere un qualcosa di de¬ 
cente che riesca anche ad utilizzare 
il suono (multimedia extension) del 6 
aprile 1992. 

Non sono passati nemmeno ventan¬ 
ni e probabilmente molti di noi non 
si ricordano che vagamente di quel 
primo sistema a finestre, così lento e 
farraginoso, ma affascinante per noi 
abituati a combattere con l’interfaccia 
a caratteri installando tutti i possibili 
ammenicoli che ci aiutassero a distri¬ 
carci nel labirinto di file-system che 
cominciava a crescere a dismisura. 
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L’avevamo installato un PC con 
Windows in azienda, era l’estate del 
1992, negli uffici pochissime perso¬ 
ne e soprattutto nessun dirigente in 
giro! Ricordo che lo facemmo in due, 
il mio collega e io, visto che eravamo 
gli unici a capirci qualcosa di sistema 
operativo. I cinque floppy vennero 
su pian pianino, come buso, sul quel 
catafalco che eravamo riusciti a re¬ 
cuperare pari ad un clone 80386sx, 
manco a colori che la scheda era 
una vecchia EGA (con l’Hercules 
non aveva voluto saperne). 


Windows Setup 


Windows Setup 



Il problema vero fu che mica ce lo 
avevamo un mouse in ufficio, così 
che dopo il fatidico WIN <INVIO> 
ci trovammo imbarazzati a cerca¬ 
re disperatamente le combinazioni 
di tasti per aprire i menù e sposta¬ 
re le finestre. Andammo a rovistare 
nel magazzino dove Giuseppe (il 
collega che se ne occupava) si fece 
bontà sua “rubare” (dicendo “lo non 
ho visto niente”) un mouse Microsoft 
ancora imballato con tanto di scheda 
dedicata. Ma non era come attac¬ 
carlo ad una porta USB, bisognava 


Windows Setup 

| Exit Windows Setup 


Windows 3.1 is now set up. 

Remove any floppy disks from youi diives. 

You need to restai! your computer so that all installed 
options can take effect. 

After restarting. type WIN at thè MS-DOS prompt to start 
Windows. 



Reboot Return to MS-DOS 
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This Tutorial has two lessons. 

■ Ifyou wantto learn howto usethe 
mouse, or ifyou need to brush up 
on your mouse skills, type M to 
beginthe Mouse lesson. 

■ Ifyou are already a skilled mouse 
user, type W to begin thè Windows 
Basics lesson. 

Or, ifyou wantto run thè Tutorial at 

anothertime: 

■ Press thè ESC key to exit thè 
Tutorial. 




lavorare di driver DOS, installando 
il dischetto allegato e poi Windows, 
bontà sua, si accorgeva che c’era. 

Per dirla tutta questo Windows 3.1 
ci piacque abbastanza; non è che 
ne fossimo proprio digiuni avendo 
visto la versione 2.0 e prima l’im¬ 
probabile DOS Executive. Come 
molti utilizzatori “power” del DOS, 
il nostro preconcetto era che Win¬ 
dows non serviva a nulla se non a 
perdere tempo e fare dei brutti di- 
segnini, seppur coloratissimi, con il 
mouse. Cosa serviva, se poi l’unica 
possibilità era stampare in bianco/ 
nero? 

Ne esplorammo però tutti i pro¬ 
grammi che lo componevano: il file 
manager prima di tutto, il pannello 
di controllo e i giochi. Devo dire che 
passammo delle ore sul solitario e 
sul campo minato, però ci vennero 
ben presto a noia, ma che volete 
farci, questo passava il convento: 
o il solitario o lavorare... meglio il 
solitario! 

Che sia stata questa prima speri¬ 
mentazione o le successive, fatto 
sta che il mio collega e il sottoscrit¬ 
to furono i primi e per lungo tempo 
anche i soli, a capirci qualcosa di 
Windows soprattutto come si pro¬ 
grammava. Merito questo del miti¬ 
co volume di Petzold “Programming 
in Windows” che studiammo fin dai 
minimi particolari con il nostro incer¬ 
to C e il compilatore Microsoft che 
riuscimmo a farci comprare quell’in¬ 
verno. 
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Che dire, un pizzico di nostalgia, 
non già per la povertà degli strumen¬ 
ti cui disponevamo, né per la invere¬ 
conda indisponibilità aziendale nello 
spendere due lire per non rimanere 
indietro con lo sviluppo dei suoi pro¬ 
dotti. Non ci credeva questa nostra 
azienda, che abbandonammo en¬ 
trambi pochi anni dopo, nel mouse e 
nello schermo a colori. “A cosa ser¬ 
vono queste stupidaggini? Basta il 
DOS” ci ripeteva il nostro capo repar¬ 
to tecnico, responsabile dello svilup¬ 
po software. Ma lui, lo si sapeva, non 
sopportava i PC e di conseguenza la 
gente che ci lavorava: gli unici siste¬ 
mi di calcolo seri erano il mainframe 
e i mini dipartimentali, tutto il resto 
erano “baracche da sala giochi”... 
Credo si stia ancora mangiando le 
mani per non aver capito in tempo 
che il mondo stava cambiando, anzi 
che era già cambiato e lui si è ridotto 
a fare il consulente organizzativo. 


[Tnl 
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Le prove di Jurassic News 


Rockwell - AIM 65/20 


C’è stata una 
stagione, alla fine 
degli anni 70, dove 
la dizione “Personal 
Computer’’ non 
aveva significato 
e quello che si 
pensava potesse 
servire era 
semplicemente un 
sistema per imparare 
ad usare il micro 
processore. 



Contesto storico 


S iamo nell’anno 1976 e il 
computer personale non 
è ancora una idea acqui¬ 
sita. Bisognerà aspettare la genia¬ 
le mente di Wozniak per avere a 
breve l’Apple 1. I microprocessori 
vengono prodotti ma in realtà non 
si sa che cosa farne. Non che le 
idee non ci siano, ma questo chip 
è troppo complicato e le sue poten¬ 
zialità sono ancora in fase di studio 
da parte dei progettisti. 


Una bella immagine pro¬ 
spettica del sistema di 
sviluppo della Rockwell; 
AIM 65 o R6500. 


In questo scenario hanno assun¬ 
to estrema importanza i sistemi di 
sviluppo messi a punto dalle stes¬ 
se ditte produttrici dei chip con lo 
scopo dichiarato di favorire la com¬ 


prensione dell’elettronica digitale 
supportata dal calcolatore ai nuovi 
progettisti. 

Non è che non esistessero prima 
i sistemi di sviluppo, i micropro¬ 
cessori e la documentazione, solo 
che era estremamente complicato 
usarli. Ad esempio Ì8080 di In¬ 
tel richiedeva una serie di chip di 
supporto indispensabili a far fun¬ 
zionare un circuito e la “potenza” 
non è che fosse così elevata. L’al¬ 
tro source, la Motorola, produce 
il 6800; ottimo chip ma costoso e 
anch’esso complicato. 

Chi produce il 6502, derivato di¬ 
rettamente dal 6800, ha necessi¬ 
tà di far conoscere le potenzialità 
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del nuovo chip ed ecco che 
nascono i vari Kim-1 dalla 
MOS Technology e appun¬ 
to TAIM 65 dalla Rockwell 
International con sede ad 
Anaheim in California, se- 
cond source per la produ¬ 
zione del chip. 

Una persona all’epoca im¬ 
piegata presso Rockwell, 
tale Mark Reardon, sostie¬ 
ne che la ditta prevedeva di 
vendere dai 400 al 600 si¬ 
stemi ma che alla fine furo¬ 
no più di 50.000 (fonte: old- 
computers.com Museum ~ 
Rockwell AlM 65). 

Il prezzo del computer con 
4 Kb di RAM si aggira at¬ 
torno ai 375 dollari, mentre 
una versione “Light”, senza 
tastiera e stampante, viene 
venduta attorno ai 175 dol¬ 
lari. 











■il 

Pjlllill 
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Kit 

nTIC 



Primo approccio 


L’AIM 65 è un computer single- 
board che viene venduto “nudo”, 
cioè senza cabinet (che apparirà 
qualche tempo dopo) e senza ali¬ 
mentatore. L’utente compra in pra¬ 
tica una piastra elettronica densa 
di componenti, una tastiera alfanu¬ 
merica di tipo telescrivente, da col¬ 
legare alla piastra madre con un 
cavo piatto di pochi centi mentri e 
una pletora di documentazione. 

A questo punto ci si deve preoc¬ 


cupare dell’alimentazione, per la 
verità non tanto difficoltoso come 
compito e soprattutto di imparare 
ad utilizzarlo questo sistema, con 
l’aritmetica esadecimale, le istru¬ 
zioni mnemoniche, gli indirizzi di 
memoria, etc... 

L’output è assicurato attraverso 
un display a led di un’unica riga da 
20 caratteri e da una stampantina 
termica delle stesse caratteristiche 
cablata direttamente sulla piastra 
madre. 

Rispetto alla concorrenza, TAIM 
65 gode di una maggiore integra¬ 
zione e professionalità che si fra¬ 


li sistema visto da sopra 
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In questa pagina una breve rassegna di contenitori approntati per rendere il sistema più simile ad un vero calcolatore , 
oltre che proteggere l’elettronica da danni accidentali. 
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duce nell’avere una vera tastiera 
per l’input dei dati, al posto della 
scomoda tastierina esadecimale 
dei sistemi di sviluppo concorrenti. 
Oltre a questo l’ampiezza del di¬ 
splay, non limitato ai quattro byte di 
indirizzo e due byte per i dati, offre 
maggiori possibilità di editing e di 
esecuzione del codice. Infine poter 
ottenere su carta il listing/dump del¬ 
la memoria è ulteriormente gradito. 

La seconda cosa di cui preoccu¬ 
parsi, dopo aver costruito l’alimen¬ 
tatore e scoperto come alimen¬ 
tare il sistema, è quello di trovare 
un panno morbido ma non troppo 
e soprattutto non conduttore, per 
appogiarvici sopra tastiera e pia¬ 
stra madre. Un’altra accortezza è 
prevedere un cavo di collegamento 
con la tastiera un attimino più lungo 
dei miseri sei centimetri di quello 
originale, permettendo un posizio¬ 
namento meno rigido delle due uni¬ 
tà una dall’altra. 

A questo punto avrete già letto il 
manuale e scoperto che i due con¬ 
nettori a pettine che sporgono dal 
retro della piastra si chiamano ‘Ap¬ 
plication” e “Exspansion”. 

La piastra supporta nativamente 
due registratori audio compreso un 
segnale per l’azionamento dei mo¬ 
tori di trascinamento della cassetta 
e una telescrivente in current loop 
da usare al posto della tastiera e 
della stampante nativa. 

La qualità della tastiera è ottima, 
garantendo un feedback alla digi¬ 
tazione non stancante, anche dopo 
ore di utilizzo. Qualche riserva sul 
display per via della luminosità non 



xvirvi 







s 

lì 1 Hi! s|;|. 






e certo non 
da utilizzare 
con legge¬ 
rezza se non 
per un listing 


esaltante e della dimensione dei 
caratteri forse troppo minuscola. 
La stampante, pur non essendo in 
tecnologia ad impatto, è comunque 
abbastanza rumorosa perché utiliz¬ 
za una tecnica di “scarica ad alta 
tensione” per bruciare la carta e far 
apparire i caratteri. 

La carta termina da utilizzare per 
la stampante, un rotolo è conte¬ 
nuto nella 
confezione 
acquistata, 
è abbastan¬ 
za reperibile 
perché usata 
anche da al¬ 
cuni modelli 
di calcolatri¬ 
ci da tavolo 
e registratori 
di cassa, ma 
è costosa 


L’abbondanza della do¬ 
cumentazione fornita in 
dotazione. 


La pagina pubblicitaria 
più classica dell’importa¬ 
tore italiano, apparsa su 
tutte le riviste di settore. 
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finale, piuttosto che attivare il sem¬ 
plice eco del video che riporta tutto 
quanto appare sul display anche 
su carta. 

Assieme alla macchina arrivano 
quattro manuali che sono: 

- AIM 65 User’ s Guide 

- AIM 65 Monitor Program 
Listing 

- R6500 Microcomputer System 
Programming Manual 

- R6500 Microcomputer System 
Hardware Manual 

Inoltre altra documentazione e 
informativa la troviamo negli alle¬ 
gati: 

- R6500 Programming Reference 
Card 

- AIM 65 Summary Card 

- Warranty Card 

Dai manuali si capisce che que¬ 
sto prodotto viene chiamato in¬ 
differentemente AIM65 o anche 
“R6500 Microcomputer”, intenden¬ 
do per la Rockwell essere un vero 
e proprio sistema di sviluppo per la 
sua soluzione di micro calcolo ma 
soprattutto micro-controllo. 

La lettura di questi manuali è una 
vera miniera di informazione che 
può costituire autonomamente un 
corso pratico di elettronica digitale, 
anche se una infarinatura è meglio 
averla già prima... 


Hardware 


La CPU è un Rockwell mp6502 
funzionante a 1 Mhz montato su 
zoccolo; per le caratteristiche del 
6502 questo significa che una 
istruzione semplice viene esegui¬ 
ta in due microsecondi. Assieme 
alla CPU la piastra ospita 4 Kbyte 
di RAM statica (ma ne esiste una 
versione “Light” che porta a bor¬ 
do un solo K), e 4 Kbyte di ROM 
contenente il monitor di sistema. 
La ROM è espandibile fino a 20 
Kb grazie alla presenza di cinque 
zoccoli in grado di ospitare ROM 
da 4Kb e che permettono di ave¬ 
re un ottimo sistema comprensivo 
di editor, assemblatore simbolico 
e disassembler. La versione ven¬ 
duta in Italia ha già 4 Kb di RAM 
e monitor espanso a 12 Kb con 
editor, assembler e disassembler. 
Esiste anche una ROM BASIC da 
8 Kb da usare al posto della ROM 
assembler e altre con altri linguag¬ 
gi come il PL/65 (una variante del 
PU1), il PASCAL, il FORTH, etc... 
che richiedono però una maggiore 
espansione di RAM, ottenibile solo 
via card esterna, per essere utiliz¬ 
zati con qualche profitto. 

Le due porte di I/O sono già pre¬ 
disposte per una interfaccia a cas¬ 
sette magnetiche e per un termi¬ 
nale TTY. A questo proposito sulla 
piastra è presente uno switch che 
esclude le periferiche interne (di¬ 
splay e stampante) in favore di un 
terminale seriale. 
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Un pulsante di Reset è accessi¬ 
bile sulla piastra in prossimità del¬ 
la tastiera. 

Come chip di supporto il siste¬ 
ma porta un 6532 per il controllo 
del timing della memoria, un VIA 
(Versatile Interface Adapter) 6522 
e un PIA 6520 (Peripheral Interfa¬ 
ce Adapter). 

La stampante a venti colonne è 
in tecnologia termica in grado di 
stampare un carattere formato da 
una matrice 5x7 con riga di stam¬ 
pa di 20 caratteri (come la riga 
del display) su un nastro di carta 
continuo di larghezza 2 pollici e un 
quarto. 

Il display a led è costituito da uni¬ 
tà a 16 segmenti, il che permette 
di riprodurre tutti e 64 i caratteri del 
set ASCII standard. 

La tastiera è una QWERTY a 54 
tasti e comprende il codice ASCII 
più tasti di controllo (Control, Shift, 
Del, Escape) e lascia liberi tre tasti 
(siglati FI, F2 e F3) per la defini¬ 
zione di funzioni utente. 


L’alimentazione non è fornita con 
la macchina (ma ne viene offerto 
uno come opzione se si preferisce 
non costruirselo), consiste in due 
tensioni: +5Volt per l’elettronica (2 
Ampere) e +24Voltperla stampan¬ 
te termica (2.5 Ampere) ed usabile 
anche come linea di alimentazione 
per altre unità collegate attraverso 
le porte di espansione. 

Il connettore di alimentazione pre¬ 
sente sulla piastra, dotato di una 



morsettiera robusta, riporta anche 
i connettori per le tensioni +12 e 
-12 Volt, da usarsi nell’eventualità 
si usino chip con queste necessità, 
ad esempio EPROM. 


La struttura del pro¬ 
getto è sufficiente- 
mente espansa da 
consentire l’appronta¬ 
mento di esperimenti 
di programmazione e 
controllo anche abba¬ 
stanza sofisticati, gra¬ 
zie alle due porte da 
8 bit programmabili, il 
contatore digitale e gli 
slot di espansione che 
portano all’esterno tutti 
i segnali dei bus di si¬ 
stema. L’esposizione 
dei segnali all’esterno 
non è protetta da chip 
di buffering, cosa che 
sarà prudente attuare 
a fronte dell’uso con 
schede di espansione 


vss il 

RDY 2 
0 X (OUT) 3 


IRQ 
N.C. 

NMÌ 
SYNC 
VCC 
AO 
Al 10 
A2 11 
A3 12 


A4 

A5 


13 

14 


A6 [15 
A7 ;16 
A8 17 
A9 18 
AIO 19 
All 20 


Un particolare della cop¬ 
pia tastiera-display. 

(Sotto) la piadinatura del 
micro processore 6502 


40 RES 
39 0 2 (OUT) 
|38 SO 
37 0 o (|N) 
|36 N.C. 

J 35 N.C. 

|34 R/W 
33 DO 
|32 DI 
31 D2 
|30 D3 
|29 D4 
D5 
[27 D6 
|26 D7 
125 A15 
|24 A14 
|23 Al 3 
22 A12 
21 VSS 
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La “mappa” hardware del 
sistema evidenzia i vari 
blocchi funzionali per la 
facile identificazione del¬ 
le componenti. 


di nostra progettazione. 

Limitata anche la possibilità nativa 
di espandere la RAM che richiede 
all’occorrenza la predisposizione 
(o l’acquisto) di una apposita sche¬ 
da in grado di codificare gli indirizzi 
necessari, oltre a portare a bordo i 
chip di memoria statica. 


Il display a 16 segmenti 
prevede una configura¬ 
zione dei led come quella 
riportata in figura. 


\\\A 

l/l\l 


I due connettori di espansione 
posti sul retro della piastra asso¬ 
migliano sorprendentemente, an¬ 
che nel nome, a quelli del KIM-1, 
un progetto analogo della MOS 
Technology. Infatti sui manuali 
vengono dichiarati compatibili con 
quelli del KIM, salvo poche 
e documentate differenze. 
Probabilmente le due socie¬ 
tà fornitrici del 6502 si sono 
accordate su questo punto 
o più semplicemente il pro¬ 
getto è stato elaborato da 
un team comune e poi diffe¬ 
renziato nei particolari e nel 
target di riferimento (TAIM65 


costa sensibilmente di più di un 
KIM-1). 


Il pilotaggio dei due registratori 
a casetta che sono collegabili alla 
macchina prevede dal punto di vi¬ 
sta del segnale due pin di uscita 
con un livello basso e un livello 
alto, da scegliere secondo le ca¬ 
ratteristiche del circuito audio di 
uscita. Prevede inoltre un segnale 
per pilotare il motore del registra¬ 
tore che può essere quindi messo 
in moto da programma. Questo 
particolare deve essere controllato 
dalTutilizzatore perché la corrente 
di commutazione potrebbe carica¬ 
re eccessivamente l’alimentatore 
delTAIM e quindi essere consiglia¬ 
bile adottare una soluzione che 
prevede il pilotaggio di un relè con 
il segnale delTAIM in modo da di¬ 
saccoppiare la periferica. 


Data la necessità di disporre di 
maggiore RAM, oltre che di ave¬ 
re a disposizione altre periferiche, 
quasi subito sono apparse delle 
schede di espansione che TAIM65 
ha in qualche caso condiviso con il 
KIM-1, altro sistema single board 
basato sul 6502 e quasi compati¬ 
bile, come affermato poco sopra. 
Le più diffuse sono state prodotte 
da una certa MTU come ad esem¬ 
pio la scheda “visible memory” o la 
scheda grafica per pilotare un mo¬ 
nitor. E’ stato prodotto addirittura 
un sintetizzatore musicale oltre ad 
altre cosucce come programmato- 
ri di EPROM, box di espansione, 
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vari sensori e attuatori esterni utili 
in esperimenti e per tenere sotto 
controllo parametri fisici come tem¬ 
peratura, tensione, etc... 

Non è un caso che la piastra 
AIM65 sia stata usata spesso come 
supporto ad esperimenti scientifici 
che prevedevano la misurazione e 
l’elaborazione dei dati; soprattutto 
si vede apprezzata la possibilità di 
pilotare i registratori con comando 
di accensione e spegnimento dei 
rispettivi motori di trascinamento 
cassette. Pare niente ma imma¬ 
ginate di dover immagazzinare il 
risultato di misure periodiche fatte 
da qualche strumento interfacciato 
con il vostro AIM65; potreste, ogni 
tanto, accendee uno dei registratori 
e registrarvi i dati letti e magari nei 
tempi morti accendere l’altro per 
leggere ed elaborare altri dati... 


Espansioni 


Ne sono state progettate e com¬ 
mercializzate parecchie, principal¬ 
mente dalla stessa Rockwell, ma 
anche molte di origine più obbisti- 
ca. 

Quasi indispensabile l’estensio¬ 
ne del bus in grado di accogliere 
più schede in una configurazione 
meccanica. Si tratta del “AIM 65 
Expansion Motherboard”, costrui¬ 
to ufficialmente dalla Rockwell è in 
grado di ospetare tutte le schede 
costruite dallo stesso produttor. 

Una curiosità l’espansione che 
ospita una memoria a bolle da 64 
Kbytes, una tipologia di Storage 
non volatile che sembrava potesse 
avere un futuro più radioso di quel¬ 
lo che gli è toccato nella realtà. 
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quindi l’AIM65 da sistema di svi¬ 
luppo in sistema di elaborazione 
personale. La scheda ha a bordo 
64 Kb di RAM e una PROM da 
256 byte in grado di “boot-are” 
dal disco il relativo CP/M. 


A questo punto 
sono attivi i coman¬ 
di del ricco monitor 
di sistema che per¬ 
mettono un discreto 
controllo delle peri¬ 
feriche e dell’esplo¬ 
razione della memo- 


Piastra base più bus di 
espansione (un insieme 
decisamente ingombran¬ 
te...). 

Nell’inserto il carattere 
prompt “<”. 

(Sotto) la scheda Z80 per 
usare il CP/M e relativi 
programmi. 


Addirittura si è prodotta da una 
certa RACO, che starebbe per 
Rockwell Anaheim Computer Or- 
ganization, una scheda con Z80 
e relativo CP/M (foto in fondo alla 
pagina). Evidentemente una scor¬ 
ciatoia per dotare il sistema di un 
ambiente applicativo compatibile 
con molto software e trasformare 


Dopo aver connesso l’alimen¬ 
tatore ci si deve assicurare che 

10 switch KB/TTY sia in posizio¬ 
ne Kb (tastiera) e che lo switch 
(RUN/STEP) sia in posizione 
RUN. A questo punto si può dare 
tensione e verificare che la pro¬ 
cedura di boot sia eseguita cor¬ 
rettamente. 

Dopo un lampeggiamento del 
display se tutto è OK, il sistema 
stampa e visualizza sul display 

11 messaggio ‘ROCKWELL AIM 
65”. A questo punto con il tasto 

<ESC> si attiva il monitor di siste¬ 
ma che ha come prompt il carattere 
'<’ (non proprio questo, ma nell’in¬ 
tenzione...), che si trasformerà in 
‘>’ dopo l’inserimento del primo ca¬ 
rattere in modo che il singolo ca¬ 
rattere iniziale della riga rimanga 
isolato ad individuare un comando 
dato al monitor. 


Uso 
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ria ed esecuzione dei 
programmi residenti in 
ROM. 



Scopo principale di 
chi acquista l’AIM65 è 
probabilmente quello 
della programmazione 
in linguaggio macchi¬ 
na. Ecco dunque che 
l’AIM65 nella configura¬ 
zione “standard” mette 
a disposizione un edi¬ 
tor e un assemblatore 
che permette di creare il sorgente 
usando le istruzioni mnemoniche 
del processore piuttosto che i codi¬ 
ci esadecimale direttamente inseriti 
in ROM. Da un certo punto di vista 
la programmazione esadecimale 
diretta è più agile per chi appronta 
piccole routine, ma indubbiamente 
è più ostica e non può godere di 
quelle features che sono tipiche di 
un linguaggio più vicino all’utente. 
Disporre di un sorgente permette 
infatti di intervenire con correzio¬ 
ni, cancellazioni o inserimento di 
istruzioni senza ricorrere ai salti 
mortali (o alla proliferazione delle 
istruzioni NOP) tipici di chi si deve 
“arrangiare” con il codice mac¬ 
china. Pensiamo ad esempio alla 
comodità delle label e dei salti re¬ 
lativi. 


per l’esecuzione. 

Con appena 4 Kb di RAM non è 
che si possano fare i salti mortali, 
ma si sa che la programmazione 
in assembly è adatta a piccoli pro¬ 
getti e non certo a migliaia di righe 
di codice. Disponibili all’utente non 
sono nemmeno tutti e quattro i Kb di 
memoria, dal momento che le due 


(Sopra) la scheda di me¬ 
moria a bolle e (sotto) la 
mappa di memoria, infor¬ 
mazione indispensabile 
per chi programma con 
i’assembier. 


L’assembler fornito in 4 Kb di 
ROM è del tipo “a due passate”; 
nel primo step il sorgente viene 
scandito per creare la cosidet¬ 
ta “symbols tabi e”, la tabella dei 
simboli, nella seconda passata si 
produce il codice macchina pronto 



UTILIZZATORE 

R6522 


NON 

OTTENIBILE 


RAM 

MONITOR 


TASTIERA 
AIM65 R6520 


NON 

OTTENIBILE 


I/O STAMPANTE 
TTY E TAPE AIM 65 R6522 


NON 

OTTENIBILE 


DISPLAY I/O 
AIM 65 R6520 


NON 

OTTENIBILE 
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prime pagine (la zero e la 1, cioè 
gli indirizzi da 0x0000 a 0x01 FF) 
sono riservate. Il microprocessore 
6502 sappiamo che non è parti¬ 
colarmente ricco di registri interni 
ma ha dei modi di indirizzamento 
in pagina zero (i primi 256 byte di 
memoria) che di fatto permettono 
di usarla come dei veri e propri re¬ 
gistri interni. 

Troviamo interessante la possi¬ 
bilità di pilotare due registratori a 
cassetta direttamente da program¬ 
ma. Questo può aiutare a mettere 
a punto un sistema per l’acquisi¬ 
zione automatica di segnali, ma¬ 
gari a fronte del verificarsi di una 
qualche situazione che genera un 
interrupt, segnali che vengono poi 


Pieghevole con le istru¬ 
zioni e i comandi dell’in¬ 
terprete BASIC. 


La Rockwell ha pensato 
a tutto: addirittura il nor¬ 
mografo con i simboli da 
flowchart. 


AHITHMETIC FUNCTIONS 



lOO lOQr»»«MOTi 

0««* «*• natura* nganVim 
o< TX «unu-un 



*nml ATM (A» 

A ■ COBO J) 

• • wo 


c - WA|C» 

0 - TAMO 14 ) 


BASIC INSTRUCTION FORMAT 

OOAiA.A.A.NMMJhU UOOAUUA.A. 

WAaea 0» . L«*MtaaM*r . • . »•*<«"•»••alanant In* 

4.A.AA. - W«il 0* !•* »Ul> 3* !**• tlAWmtnl. ■> Bm*r, 



TABLEOFERRORCODES 


i.ag»i (u«cuore»I 
a»mg enj 


■inj^N -.in».' eoeua 


MESSAGES 

ABOO^AOW J*A«t-A ■•«•«acanti C*r»el«rat 
iwnj' «U-CIIO" 

t*TAA IQNOAIO -- •» •*"» W-A-W *■* 


ZERO PACE PAHAMETERS 


J 8 " ■».*>"* H 


»» io ana* ataH IL 


««.a*, vi. Vi* «i 

AÌMAnp OBOI 


# Rockwell 

AIM65 8K BASIC 
Relerence Card 


Program SUtemanls 


Arlirwnftit f ungllons 


Rockwell Mlcroelecnome Ocvlces 
Salse Ollless 


OOC HO 2 SMCNB 


20 


scaricati su cassetta per la suc¬ 
cessiva elaborazione. Questo tipo 
di utilizzo della piastra della Rock¬ 
well è stata riportata in numerosi 
articoli apparsi su riviste specializ¬ 
zate attorno agli anni ’80. 


Da non sottovalutare nemmeno 
la disponibilità di linguaggi di alto 
livello come il principe di tutti: il 
BASIC. Il BASIC a corredo (opzio¬ 
nale) dell’AIM65 è una versione 
Microsoft standard, secondo la tra¬ 
dizione della ditta di Bill Gates, con 
la possibilità aggiuntiva di pilotare 
la stampantina interna e program¬ 
marsi delle entry per la gestione 
delle periferiche eventualmente 
usate come espansione. 

Per quanto riguarda l’utilizzo di 
altri interpreti/compilatori ritenia¬ 
mo che non siano stati in testa ai 
desideri di acquisto da parte degli 
appassionati. Ogni software ag¬ 
giuntivo, anche per il fatto che vie¬ 
ne rilasciato su ROM, ha un certo 
costo: dalle 100 alle 150 mila lire 
in Italia, il che non è proprio po¬ 
chissimo per una macchina che 
originariamente si aggira attorno 
alle 600.000 lire dall’importatore 
ufficiale. 


Software 


Dopo aver trattato dell’Assem- 
bly, linguaggio assolutamen¬ 
te d’elezione per un sistema di 
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sviluppo di questo genere, 
viene la naturale curiosità di 
esplorare le possibilità di pro¬ 
grammazione offerte dagli al¬ 
tri idiomi messi a disposizione 
dalla Rockwell. In particolare 
il BASIC e il PL/65. 

Per quanto riguarda il BA¬ 
SIC, si tratta di un classico 
“alla Microsoft” 



GET EDIT(PAT) (A); 

LINENO = 1 ; 

DO WHILE (NDFILE=0); 

GET EDIT(LINEBUF) (A); 

IF LENGTH(LINEBUF) > 0 
THEN DO; 

IX = INDEX(LINEBUF, PAT); 

IF IX > 0 THEN DO; 

PUT SKIP EDIT 
(LINENO,LINEBUF)(F(2),A); 
END; 

END; 

LINENO = LINENO + 1; 

END; 

END FINDSTRINGS; 

La funzione FINDSTRINGS rice¬ 
ve in input (file sysin) una serie di 
righe di testo e le stampa in output 
precedute dal numero di riga. 

Nel PL/I è molto interessante ed 
appare forse per la prima volta 
l’idea di trattare l’input come flusso 
di byte registrati su file. 


Un linguaggio interessante, 
perché “esoterico” rispetto al 
classico BASIC, è il PL/65, 
creato dalla stessa Rockwell 
al fine di mettere a disposizio¬ 
ne un agile idioma per la pro¬ 
grammazione di interfacce di 
controllo cui TAIM65 costituisce il 
core. 


Si tratta di un mix fra il PL/I e 
l'ALGOL, due linguaggi implemen¬ 
tati da alcuni anni sulle macchine 
mainframe e mini dipartimentali. 
Non è il caso di dilungarci troppo 
nella descrizione dei due linguag¬ 
gi “genitori” del PL/65, peraltro ben 
documentati su Internet, tuttavia un 
piccolo assaggio è utile per capire 
le origini dell’implementazione fatta 
dalla Rockewell. 


Ecco un esempio di procedura 
scritta il PL/I: 


Oltre alla documentazio¬ 
ne “ nativa”, LR6500 ha 
“goduto” di numerose mo¬ 
nografie che direttamente 
o indirettamente ne han¬ 
no esaminato e presenta¬ 
to le cvaratteristiche. 


FINDSTRINGS: PROCEDURE 
OPTIONS(MAIN); 


DECLARE 

PAT VARYING CHARACTER(100), 
LINEBUF VARYING 

CHARACTER(100), 
(LINENO, NDFILE, IX) 

FIXED BINARY; 

NDFILE = 0; 

ON ENOFILE(SYSIN) NDFILE=1; 


Per quanto riguarda I’ALGOL ve¬ 
diamo qui un piccolo esempio: 


procedure Absmax(a) 
Size:(n, m) Result:(y) 
Subscripts:(i, k); 

value n, m; 
array a; 

integer n, m, i, k; 
reai y; 
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Le riviste di informatica in 
Italia hanno cominciato 
ad uscire proprio quando 
IAIM65 era sul mercato. 
Qui la copertina del nu¬ 
mero 2 della rivista “m&p 
microcomputer” che con¬ 
tiene la recensione assie¬ 
me a quella dell’APple ][. 
La data è il 1981. 


begin 

integer p, q; 
y := 0; 
i := k := 1; 
for p:=l step 1 
until n do 

for q:=l step 1 
until m do 

if abs(a [p, q]) > 

y then 

begin 

y := abs(a[p, 

ql) ; 

i := p; 
k := q 
end 

end Absmax 

La funzione Absmax(a) 
riceve in input una matrice 
nxm di numeri interi, cerca 
il massimo assoluto e lo restituisce 
in output nel parametro Result, 
assieme alle coordinate (ij) dove 
l’elemento risiede. 

Vediamo come l’ALGOL assomi¬ 
gli molto al Pascal, che infatti da 
esso deriva. 

Il PL/65 mixa l’uno e l’altro per ot¬ 
tenere da un lato la strutturazione 
dell'ALGOL e dall’altra il paradig¬ 
ma di basso livello per l’I/O. 


Esempio bubblesort scritto in 
PL/65: 


PAGE '**SORT**'; 


DECLARE F, I, TMP; 
ENTRY $200; 


/ 


USERS 

MANUAL 



N=N-2; 

"SET TERMINAL VALUE FOR 
LOOP"; 

F = 1; "SET FLAG"; 

WHILE F = 1 DO; 

F = 0; 

FOR I = 0 TO N BEGIN; 

IF B [ I] > B [14-1] THEN 
BEGIN; 

F = 1; 

TMP = B[I] ; 

B [I] =B [1+1] ; 

B[1+1]=TMP; 

END; 

END; 

END; 

N: DATA 10; 

B: DATA 23,55,36,28,54,39,9 
9,86,21,67; 




Rockwtil InternaOonal 


EXIT ; 


Si vede come il linguaggio sia 
stato adattato per un sistema di svi¬ 
luppo. Ad esempio lo statement: 

ENTRY $200; 

dichiara l’indirizzo iniziale in me¬ 
moria del codice oggetto. 

Interessante anche la dichiara¬ 
zione e caricamento immediato 
delle variabili (N e B), in coda al 
codice. In questo caso N contiene 
il numero di elementi da ordinare 
e B è il vettore unidimensionale di 
interi da ordinare. 

Il PL/65 è talmente orientato al 
processore 6502 che addirittura le 
variabili non possono chiamarsi A, 
X, Y, P e S, che sono i nomi dei re¬ 
gistri interni al processore. Alcune 
istruzioni agiscono a livello di bit 
e richiamano direttamente le cor¬ 
rispondenti implementate nel mi- 
cro codice del processore: SHIFT, 
ROTATE, CLEAR, SET, CODE. 

Per assegnare un valore intero 
short (un byte) ad una variabile si 
possono usare le istruzioni di as¬ 
segnazione diretta o indiretta ed 
inoltre si possono forzare le loca¬ 
zioni in pagina zero per la variabi¬ 
le stessa. La pagina zero è molto 
importante per il 6502, il quale può 
accedervi con istruzioni di due 
byte, più veloci rispetto all’accesso 
alle altre pagine di memoria. 

La cosa funziona così: se si pre¬ 
mette il simbolo al nome di 
variabile, significa che vogliamo 
che sia immagazzinata in pagina 
zero. Se il carattere prefissato è 
invece “&”, allora la variabile sarà 
immagazzinata nel classico stack 
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predisposto dal compilatore in una 
pagina di memoria “alta”. 

Ad esempio: 

@T = 5 

&Z = 6. 


Bibliografia 

Wikipedia: 

http://en.wikipedia.org/wiki/AIM-65 

Wapedia: 

http ://wapedia .mobi/en/ AIM_65 

http://wapedia.mobi/en/PL/I 

http://wapedia.mobi/en/ALGOL 


Conclusioni 


Il sistema di sviluppo R6500 della 
Rockwell è tutto ciò che l’appas¬ 
sionato hobbista e il progettista di 
circuiti di controllo e automazione, 
possano desiderare. Completo, 
discretamente espandibile e abba¬ 
stanza economico per le caratteri¬ 
stiche che lo contraddistinguono, 
esso si pone al vertice dei sistemi 
di sviluppo per microprcessore che 
hanno avuto una impensabile diffu¬ 
sione prima del 1980. 

Con la sua tastiera alfanumerica 
completa, il display e la stampante 
in grado di mostrare più dei classici 
e angusti display da 6/8 nexie dei 
sistemi concorrenti, detta decisa¬ 
mente un nuovo standard in labo¬ 
ratorio. Non è azzardato ipotizzare 
che la fortuna del microprocessore 
6502 derivi per buona parte dalla 
diffusione dei sistemi di sviluppo e 
dell’AIM65 in particolare. 


[Sm] 


Recensioni 

m&p computer n. 2 
Bit n. 16, aprile 1981 

http://www.atarimagazines.com/compute/issuel/3229_l_ 

AIM_65_REVIEW.php 

http://www.dhub.org/object/164577 

http://www.atarimagazines.com/computeii/issuel/page40. 

php 

http://www.regnirps.com/Apple6502stuff/r65c02.htm 


Collezioni 

Old Computer Museum: http://www.oldcomputermuseum. 
com/aim_65 .html 
Power House Museum: 

http://www.powerhousemuseum.com/collection/ 

database/ ?im=164576 

The Freeman PC Museum Collection: 

http://www.thepcmuseum.net/details.php7RECORD_KEY 

(museum)=id&id(museum)=784&PHPSESSID=2eec6b0ff 

aa7e067 If0ae923ceaa9b5c 

Vintage computers: 

http://www.vintage-computer.com/aim65.shtml 
Old computer net: 

http://oldcomputers.net/AIM-65.html 

Old-Computers: 

http://www.old-computers.com/museum/computer. 

asp?st=l&c=58 

Manuali: 

AIM65 programming chart 
PL/65 user’s manual 

AIM 65 BASIC language reference Manual 

AIM 65 Schematic poster 

AIM 65 FORTH manual 

AIM 65 User’s Manual 

AIM 65 Monitor Guide 

MCS6500 Istruction set Summary 

R6500 Hardware Manual 


Riviste dedicate: 
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Storia dell interfaccia utente (3) 


La storia dei 
sistemi e degli 
uomini che hanno 
creato un mondo 
nuovo. 


Gli albori dell’interfaccia grafica 


Figura 1. 

La workstation “ALTO”del 
1973 ad opera dei labora¬ 
tori Rank Xerox di Palo 
Alto in California. Siamo 
ovviamente nella mitica 
Silicon Valley. 


N elle due puntate prece¬ 
denti di questa breve sto¬ 
ria dell’interfaccia utente, 
abbiamo visto una rassegna di 
metodi e apparecchi progettati allo 
scopo di consentire una comuni¬ 
cazione efficace fra uomo e mac¬ 
china. E’ venuto ora il momento di 
addentrarci in quella che oggi vie¬ 
ne considerata la “vera”interfaccia 
utente, cioè quella che fa uso della 
grafica per impostare il paradigma 
della scrivania. 

Fin dall’inizio degli anni settan¬ 
ta, le aziende più attive nel setto¬ 
re dell’elaborazione dati, stavano 
studiando la possibilità di dotare 
i sistemi di una interfaccia grafica 
a pixel. Le motivazioni si ritrovano 
soprattutto per il fatto che erano 



nate le Workstation, un sistema 
molto simile nelle prestazioni ad 
un mini dipartimentale, ma dedi¬ 
cato all’uso personale. Avere a di¬ 
sposizione una macchina di clas¬ 
se workstation era costoso e se 
ne giustificava l’adozione solo a 
fronte di elaborazioni molto parti¬ 
colari e “pesanti”, come la grafica 
industriale, appunto. 

Capofila di questi esperimenti 
è stata la Xerox Corporation, ma 
non la sola, anche se è rimasta 
questa ditta nelTimmaginario col¬ 
lettivo, grazie sostanzialmente alla 
leggenda secondo la quale Steve 
Jobs ne avrebbe rubato i segreti 
per progettare l’interfaccia del Lisa 
prima e del Mac subito dopo. 

Il primo tentativo di Xerox si con¬ 
cretizza nel prodotto denominato 
Alto (vedi figura 1). Non è proprio 
quello che i tecnici volevano ma ci 
stavano lavorando... 

Tralasciando i tentativi più o 
meno riusciti che sono seguiti a 
questo primo esperimento, vale 
comunque la pena citare la Three 
Rivers Computer Corporation, che 
nel 1980 mette in commercio una 
workstation grafica chiamata Perq 
Graphical Workstation (figura 2) 

Saltiamo subito al 1981 quando 
la Xerox rilascia il suo sistema gra- 
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fico Star (Figura 3). 

Si tratta di una workstation con 
display a toni di grigio con icone, 
finestre sovrapponibili e ovviamen¬ 
te mouse. 

Incomincia a delinearsi la strada 
maestra da seguire: grafica, pun¬ 
tatore con mouse e finestre come 
contenitori dei task in esecuzione 
sul sistema. 

Il sistema Star di Xerox si dice co¬ 
munemente sia il papà (putativo) 
del primo Mac, cioè il Lisa di Apple, 
uscito nel 1983 e che ha spariglia¬ 
to le carte rispetto al mercato dei 
sistemi personali (Figura 4). 

Il Lisa si andava a mettere nella 
fascia di prezzo a metà strada fra il 
costo del personal e la workstation 
scientifica più sofisticata. Purtrop¬ 
po sappiamo che l’idea era buona 
ma il momento non favorevole. Il 
secondo e più abbordabile tenta¬ 
tivo di Apple avvenne con il Mac 
Hintosh nel 1984, solo pochi anni 
dopo il Lisa ma una “vita” distante 
in termini informatici. 

Il sistema operativo Mac conser¬ 
va gli elementi fondamentali di Lisa 
ma si orienta verso l’utilizzo per un 
utente meno esperto e in posses¬ 
so di una piattaforma elaborativa 
migliore. 

Lisa, aldilà della novità tecnologi¬ 
ca e dell’interazione grafica, ha in¬ 
trodotto un concetto fondamentale 
che poi Apple non abbandonò mai: 
il paradigma dell’iterazione ad og¬ 
getti. Ogni elemento a video rispon¬ 
de alle stesse azioni (ad esempio 



al click del 
mouse) in 
maniera 
differente, 
è cioè poli¬ 
morfico. Per 
l’utente è un 
grande van¬ 
taggio per¬ 
ché non si 
deve chie¬ 
dere cosa 
ci stia sotto 
l’oggetto ma 

interagire con esso esattamente 
come farebbe con un oggetto fisi¬ 
co deposto sulla sua scrivania. 

Il PC IBM, rilasciato nel 1981, ha 
avuto vari tentativi nel senso gra¬ 
fico. 

Uno di questi è VisiOn della Visi 
Corporation (quella che produce¬ 
va il Visicalc). VisiOn ha lo stile 
mac-iano ma cerca di differenziar¬ 
si almeno per il posizionamento 
del menù, che si trova sul piede di 
ogni singola finestra; quando inve¬ 
ce il menù generale stile Mac, che 


Figura 2. 

La worstation grafica della 
Three Rivers. 


Figura 3. 

La grafica del sistema Star 
di Xerox. 
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trasforma in eleganza (figura 6). 

Dopo il Mac e la sua ecclatante 
presentazione pubblicitaria costa¬ 
ta una piccola fortuna all’azienda 
di Jobs e compagni, esce GEM 
della Digital Research (quella del 
CP/M), che crea un ambiente por¬ 
tabile (ne esistono versioni per 
Commodore 64, Atari ST, etc...), 
basato su icone e finestre sovrap¬ 
ponibili. 


Figura 4. 

La scrivania virtuale del 
Usa di Apple. 


Figura 5. 

VisiOn, la proposta di 
Visicorp. SI noti l’idea 
primitiva del menù nel 
piede della finestra, una 
pratica che non ha preso 
piede (è il caso di dirlo!) 


si trova nella parte alta del video, 
è quanto più comodo e naturale 
si possa concepire, ma sembra 
l’abbia capito solo 
Apple (Figura 5). 


GEM è quasi un Mac-clone e 
nemmeno tanto camuffato...(figu¬ 
ra 7). 
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E siamo giunti 
così al 1984, anno 
Orwelliano dalle 
inquietanti predi¬ 
zioni... Il 1984 è 
un po’l’anno d’oro 
delle interfacce 
grafiche. Il Mac di 
Apple trova la sua veste definitiva 
con un maggiore sobrietà che si 
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Figura 1. 

Il GEM ha conosciuto una 
discreta fortuna, come si 
vede meritata. 
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Un’altra pietra miliare, siamo 
sempre nel 1984, è l’uscita del 
sistema X Window del MIT. 

Confezionato in diverse “taglie” 
il sistema X Window si adatta ad 
ogni tipo di terminale e può esse¬ 
re configurato da un utente con 
qualche capacità tecnica. Gira 
sotto Unix e successivamente 
diventerà l’ambiente grafico di 
GNU/Linux. 
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X Window è tutt’altro che un am¬ 
biente monolitico. Già abbiamo 
accennato alla possibilità di confi¬ 
gurarlo attraverso dei file di testo, 
ma anche di appiccicarci sopra 
una libreria grafica che vada ad 
occuparsi dell’aspetto delle fine¬ 
stre e degli altri elementi. Una di 
queste librerie, famosa per diffu¬ 
sione, è stata Moo-tif, adottata da 
Sun Corporation per la linea delle 
suo Workstation grafiche basate 


Il 1984 volge al termine ma è tut¬ 
to un fermento. Cosa ci riserverà 
il futuro? Tutti parlano di qualcosa 
che sta preparando la Microsoft... 
Staremo a vedere. 


[Tn] 


Figura 6. 

La scrivania Mac nel¬ 
la sua versione 1984 
ma che rimarrà pra¬ 
ticamente la stessa 
per lungo tempo (a 
parte l’introduzione 
del colore). 


sullo Unix BSD. 


Figura 8. 

Xwindow, ovvero la 
soluzione Unix al 
problema della inter¬ 
faccia grafica. 



tlanual Browser 


nacbook 






rtanual Page 


Options Sections 


The current nanual page is: xset<x>. 


XSET(l) 


XSET(l) 


preference utility for X 


SYNQPSIS 

xset I-display display] [-b] (b on/off) [b [volume [pitch [ohration]] 

( I-1 bc 1 [-c) [c on/off] [c (voiume]] [[+-]dpms] [dpms standby [ suspend 
[ off]]] [dpm3 force standby/suspend/off/on] [ [] fp [-+=] 
pa£A[.pa£À[, . . . ] ] ] [fp default] [fp rehash] [ [ - ] led [integer ]] [led 
on/off] [m[ouse] [accel_mult[/accel_div] [threshold] ] ] [m[ouse] 
default] [p pixel color ] [ [-]r [keycode]] [r on/off] [r rate delay 
[rate]] [3 [lertgth [periorf] ] ] [s blank/noblank] [3 expose/noe?q)03e] [3 
on/off] [s default] [s activate] [3 reset] [q] 

DESCRIPTION 

This program 
play. 


used to 3et various 


preference options of thè dis- 


-display display 

This option specifies thè server to 


The b option Controls bell volume, pitch and duration. This 
option accepts up to three numerical parameters, a preceding 
dash(-), or a 'on/off' flag. If no parameters are given, or 
thè ’on' flag is used, thè System defaults vili be used. If 
thè dash or 'off' are given, thè bell will be turned off If 
only one numerical parameter is given, thè bell volume will be 
set to that value, as a percentage of its maximum. Likevise, 
thè second numerical parameter specifies thè bell pitch, in 
hertz, and thè third numerical parameter specifies thè duration 
in milliseconds. Note that not all hardware can vary thè bell 
characteristics. The X server will set thè characteristics of 
thè bell as closely as it can to thè user's specifications. 


The bc option Controls bug compatibility mode in thè server, if 


)ec 5 23:55 
tee 5 23:55 
tee 5 23:55 
tee 5 23:55 
ec 5 23:55 
tee 5 23:55 
tee 5 23:55 
tee 5 23:55 
tee 5 23:55 
tee 9 12:31 
tee 9 13:56 
tee 13 21:54 
an 29 20:23 
'eb 15 23:08 
eb 15 23:11 
eb 15 23:11 
eb 15 23:19 
eb 15 23:19 
eb 15 23:20 
eb 15 23:20 
eb 15 23:20 
eb 15 23:20 
xeenshot 


octave-bug-2.1.72 

octave-bug -> octave-bug-2.1.72 

octave-2.1.72 

octave -> octave-2.1.72 

mkoctfile-2.1.72 

mkoctfile -> mkoctfile-2.1.72 

negen 

nedump 

blas-config 

oneko 

neko -> oneko 

unrar 

xdaliclock 

xsetroot 

oclock 

xconsole 

xcalc 

xbiff 

xset 

xeyes 
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Storie di vita 
dove i computer 
(soprattutto retro 
computer) c’entrano 
in qualche modo. 


Dove si racconta come divenni fi¬ 
nalmente “tecnico elettronico”. 

E ra uno degli ultimi giorni 
della mia esperienza di 
stage e il mio futuro da¬ 
tore di lavoro era venuto per tirare 
le fila e decidere se ero adatto o 
meno alla sua azienda. Credo che 
nella decisione di prendermi e nel 
parere favorevole del sig. Tiziano, 
pesasse più quella giornata di fac¬ 
chinaggio dei biliardi piuttosto che 
la fiducia nelle mie capacità tecni¬ 
che, ma tant’è fui promosso con 
l’invito a presentarmi di li a quindi¬ 
ci giorni nell’azienda che sarebbe 
diventato il mio posto di lavoro nei 
prossimi due anni. 

Era il mio turno di decidere: ci do¬ 
vevo andare lasciando il mio lavo¬ 
ro in fondo comodo di commesso 
sulla soglia di casa per fare ogni 
giorno venti più venti chilometri di 
macchina e trovare anche il modo 
di mangiare a mezzogiorno. Se 
avessi avuto tutte le carte in mano 
per decidere probabilmente sa¬ 
rei rimasto dov’ero: ci stavo bene, 
guadagnavo poco ma in manera si¬ 
cura, avevo ferie e permessi pagati 
e un sacco di tempo libero proprio 
per la tipologia di orario. 

Sì, mi pesava lavorare di sabato e 
di domenica, ma le mezze giornate 


di chiusura, ricordo erano il lunedì 
e il mercoledì, mi permettevano di 
seguire molti interessi. Avevo natu¬ 
ralmente tentato di proseguire con 
l’Università ma presto mi resi conto 
che non era possibile. Ammiro in¬ 
condizionatamente chi ci riesce; io 
non ero fra questi. 

Ma ci stavo stretto, l’ho già detto, 
in quel supermercato di paese e 
sapevo che sarei potuto crescere 
sono seguendo una carriera che 
non mi attirava, sostanzialmente 
quella del direttore di un reparto 
prima e di un negozio poi. Poi c’era 
l’informatica, materia del tutto nuo¬ 
va nei primi anni ’80 e che mi ave¬ 
va appassionato e convinto che li 
c’era da lavorare e che non dovevo 
perdere il treno dell’innovazione se 
volevo far fruttare un poco le mie 
doti di intelligenza. 

Decisi quindi di licenziarmi e fir¬ 
mare il contratto per la nuova av¬ 
ventura dove io mi qualificavo 
“tecnico elettronico”, ma sul libretto 
di lavoro, nella colonna “qualifica” 
figurava un più umile “operaio”. 

Il mio nuovo datore di lavoro si 
chiamava Romano ed era una per¬ 
sona buona di animo, ne sono con¬ 
vinto, però anche lui era soggetto 
alla malattia che fa incrinare l’one¬ 
stà dei piccoli imprenditori-commer- 
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cianti-artigiani: l’idea che siccome 
loro ti pagano, cioè tu mangi grazie 
a loro, li autorizza a trattarti come 
una cosa loro, senza molti diritti. 

Nella mia ingenuità avevo discus¬ 
so solo l’importo mensile del salario, 
decidendo con Romano che sareb¬ 
be stato pari al posto che lasciavo, 
e dell’orario di lavoro alla cui mia 
domanda Romano aveva risposto 
semplicemente con “la mattina si 
comincia alle nove e il sabato nor¬ 
malmente non si lavora”. 

Il lavoro che lasciavo era normato 
in maniera completa: orario, ferie, 
malattie, scatti, pensione, straordi¬ 
nari,... insomma tutto era chiaro e 
trasparente e non capii immediata¬ 
mente che le cose sul nuovo posto 
di lavoro potevano essere diverse, 
molto diverse. Quando cominciai a 
realizzare che mi ero messo in una 
trappola era troppo tardi: avrei po¬ 
tuto tornare indietro, rinunciare al 
lavoro e ripresentarmi sul mio vec¬ 
chio posto di lavoro implorando di 
essere ripreso? Sì, l’avrei potuto e 
con la mia esperienza di oggi lo fa¬ 
rei, ingoiando il mio orgoglio assie¬ 
me al mio amor proprio. Ma allora 
ero giovane, fiducioso, credulone... 
Una combinazione di dis-qualità 
foriere di guai e nemiche della vita 
stessa. 

Romano non fu del tutto onesto 
nei miei confronti, un po’ mi dispia¬ 
ce affermarlo, ma non posso dire 
che lo fu. Prima di tutto il contratto 
non lo firmai il primo giorno ma una 
settimana dopo (il commercialista 
non l’aveva ancora preparato), poi 
scoprì che l’assunzione era datata 


il primo giorno del mese successi¬ 
vo (“per ragioni di ordine, ma non 
ci avrei perso nulla”), infine non 
poteva non dirmelo che sarei sta¬ 
to assunto formalmente per quattro 
ore al giorno (“le tasse sono così 
care!”). 

Rimasi negativamente impressio¬ 
nato dalla notizia e dalla manfrina 
che tirò giò Romano sul fisco che 
strozzava la libera iniziativa e che 
lui non poteva permettersi di “met¬ 
termi in regola” per otto ore, etc... 

Che potevo fare? Buttai giù quel 
boccone amaro cercando di non 
pensare che stavo mettendo a re¬ 
pentaglio il mio futuro. Quando si è 
così lontani dalla pensione non ci si 
pensa molto che un mese di contri¬ 
buti persi da giovani si traduce in un 
mese di fatica da vecchi... 

L’orario di lavoro è vero che ini¬ 
ziava alle nove, ma quando finiva 
lo sapeva solo il cielo! Normalmen¬ 
te alle sei del pomeriggio si pote¬ 
va andarsene, ma questo era vero 
solo se il titolare non era presente, 
altrimenti trovava sempre qualcosa 
da fare, almeno fino alle sette, ora 
in cui andava a cena. Senza conta¬ 
re che spesso eravamo in giro per 
installare giochi nei bar e ritirare gli 
incassi e ovviamente ci si rimaneva 
fino a che tutto era a posto e il giro 
completato. 

La media giornaliera era di nove 
ore, ma non si timbrava e quindi 
tutto andava “in cavalleria”. E’ vero 
che Romano ti riconosceva un plus 
in nero sullo stipendio, ma eviden¬ 
temente conveniva a lui più che a 
noi. Il sabato “di norma” era libero, 
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questo aveva detto il titolare nei colloqui prima 
dell’assunzione. Mi sembrava logico che una 
azienda che viveva di incassi di macchinette da 
gioco potesse chiedere un impegno straordinario 
ai suoi dipendenti piuttosto che lasciare guasta 
una macchina durante il week end. Il problema 
era che queste emergenze erano costanti e al¬ 
meno la mattina si lavorava sempre, nel pome¬ 
riggio invece qualche volta si staccava. Per pro¬ 
vare e per ri picca inventai delle scuse rispetto 
alla mia necessità di essere libero di Sabato. La 
prima volta me lo concesse, la seconda fece una 
smorfia e la terza mi disse chiaramente che lì, in 
azienda, tutti lavoravano di Sabato e che lui non 
poteva permettersi, etc, etc.... 

Durante il week end e le assenze in genere il 
titolare non si faceva scrupoli di chiamarti a casa 
e chiederti, sempre molto gentilmente, di “anda¬ 
re a dare un’occhiata” in quel certo Bar perché 
il gioco era fermo o le palline del calcetto non 
uscivano (normalmente i ragazzi ci mettevano 
dentro palle di carta per bloccare le porte e non 
far entrare la pallina o ci giocavano addirittura 
con le palline fatte di carta e elastico). Succe¬ 
deva anche che il il titolare del locale chiamas¬ 
se perché aveva bisogno di moneta ed era una 
molla che faceva scattare Romano: neiente mo¬ 
neta uguale niente soldi nelle macchine uguale 
niente guadagno. Una tautologia, direi. 

Dopo un po’ di tempo i gestori della zona mi 
chiamavano direttamente a casa, sia la domeni¬ 
ca che di sera e quanto valesse questa presenza 
disponibile ne ebbi una misura poco dopo quan¬ 
do lo stesso titolare mi disse con soddisfazione 
che si vedeva che ci tenevo al lavoro perché gli 
incassi erano superiori a quelli che si riusciva a 
fare prima negli stessi esercizi. Ne fui compia¬ 
ciuto, non lo nego: per tradizione famigliare il la¬ 
voro è sempre stato sacro in casa nostra. Ormai 
ero nel giro e mi conveniva ballare facendo buon 
viso alle magagne che il mio rapporto di lavoro si 
portava dietro e ricavare da esso i vantaggi che 


mi convenivano. 

Mi preoccupai seriamente quando con un certo 
giro largo di parole Romano mi disse che alla 
fine dell’anno mi avrebbe licenziato per riassu¬ 
mermi all’inizio di gennaio. Diceva che mi con¬ 
veniva: avrei ritirato il TFR subito e non so quale 
fosse la sua di convenienza, ma naturalmente 
una doveva pur esserci. Ricevetti quindi lettera 
di licenziamento verso il 10 di dicembre mentre i 
soldi del tfr mi sarebbero stati pagati in gennaio. 

Confesso che dubitai che mi riprendesse, ma 
invece fu proprio così. Mi presentai regolarmen¬ 
te al lavoro in gennaio e dopo una decina di gior¬ 
ni mi chiamò in ufficio per farmi firmare il nuovo 
contratto che, guarda caso, avrebbe avuto corso 
dal primo di febbraio. Sembra che una qualche 
norma impedisse ad un datore di lavoro di rias¬ 
sumere una persona senza uno stacco tempora¬ 
le. Un paio d’anni più tardi ne parlai casualmen¬ 
te con un sindacalista che mi confermò nei miei 
sospetti: non era affatto vero; ancora una volta 
Romano si “tirava su le maniche”, diciamo così, 
guadagnandoci comunque sempre. 

Quindi lavorai il gennaio in nero (altro mese da 
fare in più per la pensione), ricevendo il normale 
stipendio di prima ma dei soldi che lui risparmia¬ 
va non pagandomi gli oneri fiscali e previdenziali 
non se ne fece cenno. Mi chiedo oggi cosa sa¬ 
rebbe successo se mi fossi fatto male durante 
quel mese. D’accordo i rischi erano limitati ma 
comunque si era spesso in giro in macchina e le 
scosse da filo di alimentazione scoperto erano 
all’ordine del giorno... 

Mi vergognavo a recarmi dai sindacati a far 
controllare le mie buste paga e il calcolo del tfr 
che era esiguo, visto che avevo lavorato solo 
tre mesi ufficialmente in quel primo anno. Non 
mi passò nemmeno nell’anticamera del cervello 
che forse non avevo fatto nemmeno un giorno 
di ferie e che avrebbero dovuto essermi pagate. 
Protestare? Ora lo farei e non avrei paura del- 
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le conseguenze, ma allora avevo l’orgoglio da 
zittire e dimostrare ai miei genitori, che me ne 
avevano sconsigliato, che invece avevo fatto la 
scelta giusta. 

Però il lavoro mi piaceva abbastanza; c’era da 
lavorare sodo la maggior parte del tempo, ma 
c’erano pure giornate in cui si faceva poco o nul¬ 
la e si passavano interi pomeriggi a giochicchia¬ 
re con qualche titolo appena riparato in laborato¬ 
rio o presso i clienti. 

Andare a zonzo in due per tutta la regione era 
piacevole e andavo molto d’accordo con Daniele 
che era un ragazzo delizioso al punto che non 
ricordo il minimo screzio fra noi nei due anni che 
sono rimasto in azienda. Quasi ogni giorno era 
una avventura e devo dire di aver girato tutta 
la provincia come mai avevo avuto occasione 
di fare prima. Ovviamente si bigiava quel poco 
che ci era consentito, rientrando in ditta dopo le 
cinque anche se alle quattro avremmo potuto 
esserci tranquillamente. In qualche modo biso¬ 
gnava pur difendersi: fosse stato per Romano 
avremmo fatto dodici ore di lavoro al giorno! E 
Daniele ne conosceva di trucchi! Che ingenuo 
ero al suo posto: mai ero stato nella necessità 
di “fregare” il capo, di imboscarmi o fingere di 
lavorare. Ero del tutto nuovo nel “settore”. 

Ci si fermava poi a mangiare in certi ristorantini 
che Daniele conosceva e frequentava regolar¬ 
mente durante i giri di riparazione, oppure in certi 
Bar dove la cameriera era così carina o nella sa¬ 
letta di sotto si poteva giocare a bigliardo lontani 
da occhi indiscreti. Parcheggiavamo allora un 
po’ lontano, dietro la chiesa, e si passava buona 
parte del pomeriggio in attesa che arrivassero le 
cinque per rientrare. 

I trucchi per sopravvivere erano infiniti e Danie¬ 
le me li fece sperimentare tutti. All’inizio avevo 
una paura folle di arrossire davanti a Romano 
che chiedeva spiegazioni del ritardo o di altre 
cose. Poi ci feci l’abitudine, molto in fretta, lo 
confesso. Una delle tecniche preferite era finge¬ 


re di non essere stati in grado di aggiustare un 
gioco perché ci mancava quel pezzo e si doveva 
ritornare nel pomeriggio. Invece il gioco era sta¬ 
to aggiustato ma non eravamo tanto ingenui da 
dirlo al titolare del Bar, casomai Romano avesse 
telefonato per una conferma. 

Arrivammo addirittura a mettere delle richieste 
di intervento fittizie sulla segreteria telefonica 
con la complicità di un amico, per indurre il ti¬ 
tolare a mandarci di urgenza il lunedì mattina in 
quella certa località turistica in riva al lago o in un 
rifugio di montagna addirittura. Un po’ di rischio 
c’era perché Romano era per sua natura diffi¬ 
dente e pensandoci non mi sovviene come mai 
non abbia mai scoperto i nostri trucchi... 

Girare da solo, senza il mio comagno di avven¬ 
ture, mi piaceva molto meno ma mi organizzai 
presto e con una certa abilità riuscivo a ritagli¬ 
armi qualche mezz’oretta di relax lontano dalle 
grinfie del capo. Portavo allora la macchina in 
certi posti di periferia dove trovavo spesso, im¬ 
boscati quanto me, i militari delle caserme citta¬ 
dine. Questi, invece che andare su e giù per fare 
scuola guida agli allievi, preferivano nascondere 
camion e camionette dietro la siepe di certi po¬ 
sti strategici e passare li il pomeriggio giocando 
a bigliardino o a flipper e a bere qualche birra. 
Era facile fare amicizia con loro: per una strana 
combinazione avevo fatto la naia nella stessa 
caserma e una generosa manciata di gettoni per 
il flipper apriva i loro cuori alla fiducia. 

Venne la primavera e poi l’estate e poi di nuovo 
l’autunno: avevo completato il giro di calendario 
di quel mio primo anno alla Automatik. Non ne 
feci di bilanci, non ero in grado e non sarei sta¬ 
to sereno. Mi pesava essere in regola per metà 
giornata e dovevo farlo presente. Ma un’altra 
idea stava maturando e fu quella che mi guidò 
su una strada diritta. 

Ma questa è un’altra storia. 

[Lp] 
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Edicola 



In edicola o sul 
Web le riviste 
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di computer, 
preferibilmente 
retro o free 
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VCF Staff 
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Prezzo: Free 
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Hello Vintage Computer Fansl Welcome to thè first issue of what is guaranteed to 
be an irregularly published newsletter to keep you up to date on thè latest events 
and happenings of thè Vintage Computer Festival. 

There is a lot going on this year. We have two major events, VCF Europa 3.0 and 
VCF 5.0, and an Open House at our Oakland, California, facility. 

VCF Europa 3.0 

The third annual Vintage Computer Festival Europa is being held Aprii 27th and 
28th in Munich, Germany. If you have a chance to be in Munich during thè lost 
weekend of Aprii, you should certainly attend. Youll get a toste of thè vibrant 
computer industry and thè varied computers that were produced in Europe from 
over ten years ogo and beyond. 

For more information on VCF Europa 3.0, visit: 

hflp Jl vrw.Ytnlage.Qrg/2QQ2/eurQpa/ 

-or- 

hHp;//www vcfe.de/ 
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Vintage Computer Festival 


VCF Gazette 

A Newsletter f«r thè Vintage Computer Festival 


Moy 12, 2005 
Volume 3, Issue 1 


Q uesta fanzine è stata 
pubblicata dal 2002 al 
2005 con periodicità 
trimestrale fino all’ultimo numero 
che è del marzo 2005. Si tratta in 
totale di nove numeri pubblicati sul 
Web che trattano i temi del retro 
computer legati alla manifesta¬ 
zione Vintage Computer Festival. 
Questa organizzazione culturale 
mantiene un sito Web con lo sco¬ 
po primario di sostenere le iniziati- 


Events 
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Donate 
Sponsors 
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Mailing List 
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Contact 
Login 


Wow! The VCF Gazette marks a milestone as it rolls in to its 3rd year And boy are we late 
Later than usuai. Very late. In foci, l'm positive we’re later than we've ever been. But my we're 
busy here al VCF centrai. Busier than usuai. Very busy. In faci, l'm positive we're busier than 
we've ever been. So there you have it. Anyway, on with thè news! 

In This Issue: 

VCF 7,0 Wrop Up 

VCF 7.Q bdiibil Awgrda and Photo Gallery 

YCf Midwfid 'Lite' 

VCF Inouqurates Lonq-Term Doto Archiving Standard: FutureKeep 

New YCf Website features 

YCF Z.Q Wrap Up 

The 7th annual Vintage Computer Festival was held on November 6-7 at thè Computer History 
Museum in Mountain View, California, It’s pretty much diche at this point to say it was thè besi 
event yet, but it really was! Just ask thè 450+ people who attended. 

The main feature of thè VCF this last lime around was thè Maze War Retrospective hosted by 
Bruce Oamer of thè Di giBorn . The authors of Maze War, which is thè originai “first person 
shooter" videogame, discussed thè developmenl of thè game in thè eady 1970s. The Maze War 
server was ported to thè PC by Ken Harrenstien and a Maze War network of three PCs plus an 
Imlac PDS-1D (heroically provjded by Tom Uban) was installed at thè VCF, allowing attendees to 


ve du ricerca e culturali relative la 
retro computing. 

Primaria attività del gruppo, al 
quale si può aderire anche virtual¬ 
mente, è l’organizzazione delle 
Exibitions che si svolgono rego¬ 
larmente due/tre volte all’anno in 
varie sedi europee. 

Peccato che non si sia ritenuto 
di continuare nell’iniziativa della 
gazzetta, non fosse altro che per 
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fissare in una pubblicazione pe¬ 
riodica i progetti salienti dell’orga¬ 
nizzazione. Il Web è un sostituto 
fantastico, senza ombra di dubbio, 
però sappiamo tutti quanto sia fra¬ 
gile in un certo senso: non paghi 
il dominio e sei fuori, invisibile al 
mondo e senza nessun passato! 

Dobbiamo leggere questo pe¬ 
riodico con la giusta ottica che è 
appunto quella della celebrazio¬ 
ne delle attività del gruppo in una 
esposizione molto spartana, sen¬ 
za grafica o altro supporto multi¬ 
mediale. Per trovare la documen¬ 
tazione, soprattutto fotografica, è 
obbligatorio visitare il sito che è in 
linea con la grafica della fanzine 
ma ricco e ben organizzato. 


Vintage Computer Festival East B.D 

September 12-13, 2009 

InfoAge Science Center, 2201 Marconi Rd., Wall, N.J., 07719 
Salurday: 10 a.m. - 6 p.m. *** Sunday: 10 a.m. - 5 p.m. 
Tickets: $10 (1 day), $15 (both days), FREE for 17 and younger 

Special events @ VCF: 

S Keynote: RCA Computers in thè 1950s 
H 8-bit live music and visual concert 
H PockeTerm Constiuction Workshop 
H BASIC Programming Challenge 
H Aftemoons: Exhibit hall with live demos 
H Technology by-the-pound book sale 
B Museum guided tours all weekend long 

Details frequently updated at www.vintage.org 
Contact Evan Koblentz, evan@ snarc.net/ (646) 546-9999 

Sponsors: 

I10BÌS vìntagéTEEH 

_ ITM-RHanhc Petto CoirpuHng HnbbijlBtg 1 _ 


VCF è un po’quello che molti ap¬ 
passionati spererebbero di poter 
realizzare anche in Italia, pur con 
le difficoltà obiettive dovute alla 
numerosità non certo stratosferica 
dei praticanti nostrani. 


[Sn] 


La locandina dell’ultima 
esibizione (al momento 
in cui scriviamo) avvenu¬ 
ta nel settembre 2009. 


Un angolo dell’esibi¬ 
zione VCF set. 2006 
Si noti la cura e l’ele¬ 
ganza (a parte gli sca¬ 
toloni sotto il tavolo) 
con la quale vengono 
realizzati i punti infor¬ 
mativi. 
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Retro Riviste 




La rassegna 
dell’editoria spe¬ 
cializzata dai primi 
anni ‘80 ad oggi 


Scheda 

Titolo: 

G/gaByie 

Sottotitolo: 

internet- 
Programmazione 
- Computer ildt/sic - 
P/xeiMedia 

Editore: 

Xenia Edizioni 


Lingua: 

Italiano 

Primo numero: 


1993 

Ultimo numero: 


1995 

Prezzo 

L. 6.000 



E dita a cura della Xenia 
Edizioni, la rivista uscì 
approssimativamente dal 
1993 al 1995. Una classica me¬ 
teora, insomma, come tante altre 
testate non solo elettroniche ed in¬ 
formatiche. Molto curata dal punto 
di vista grafico si proponeva ad un 
target squisitamente hobbistico 
concentrandosi sulla recensione 
di programmi per sistemi PC. 

Devo dire di averla seguita con 
molto interesse anche perle quali¬ 
tà che ne permettevano una lettu¬ 
ra rilassata, tipica rivista “da viag¬ 
gio”, ma contemporaneamente 
utile per ampiare la propria cultura 
informatica. 


È necessario ritornare agli anni 
94195 e alla situazione dell’infor¬ 
matica personale di allora per 
comprendere l’interesse che 
questa rivista ha suscitato e per 
capire la sua prematura scom¬ 
parsa. Internet è un miraggio 
mentre la connettività via BBS è 
ampliamente diffusa. Contempo- 
ranemente esplode il mondo del¬ 
lo shareware: programmi da pro¬ 
vare gratis per poi non comprarli 
mai (soprattutto in Italia, ma non 
solo). I programmi Shareware 
si trovano o sulle BBS o sui cd¬ 
rom che arrivano dagli Stati Uniti. 
Chi no ricorda ad esempio il “Si- 
mTel”, una raccolta sterminata di 
programmi per ms-dos su due cd¬ 
rom? Qualsiasi cosa tu avessi bi¬ 
sogno li la trovavi sicuramente. 

Internet invece latita fuori del¬ 
le Università. La Tecnimedia di 
Roma, attraverso McLink offre il 
collegamento ma l’utilizzo è a dir 
poco ridicolo. Infatti il tutto funzio¬ 
na via X25 (Itapac) con rifattura¬ 
zione basata sul traffico a velocità 
2400 bitlsec al massimo (e era già 
qualche cosa, visto che il modem 
più diffuso andava a 300 bitlsec). 
Insomma non è che ti venisse una 
voglia pazza di collegarti! 
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GigaByte si propone come recen¬ 
sore di programmi di ogni tipo ma 
principalmente dei prodotti share¬ 
ware e freeware che sono così fa¬ 
cilmente reperibili. Credo che uno 
dei motivi che contribuii alla diffu¬ 
sione del periodico sia stata la no¬ 
toria scarsa padronanza della lin¬ 
gua inglese da parte di noi italiani 
e la conseguente difficoltà nel leg¬ 
gere i manuali allegati al software. 
Negli articoli trovavi tutto quello che 
serviva per installare e cominciare 
a lavorarci. 

La decisione dell’editore di so¬ 
spendere le pubblicazioni e di far 
confluire la redazione in un’altra ri¬ 
vista, sempre edita da Xenia: ‘‘PC 
Action”, mi lasciò scontento! Non 
perché PC Action fosse una rivista 
da buttare, ma perché la trovavo 
“fuori sintonia” sia per il fatto che 
era incentrata sui giochi ma soprat¬ 
tutto per l’accozzaglia di argomenti 
impaginati senza logica e perché 
erano usati degli sfondi colorati per 
le pagine che rendevano la lettura 
dei testi un vero calvario. Maga¬ 
ri non è più così e potrei rivedere 
questo giudizio, un giorno di questi 
ne prendo un numero e controllo. 

Gigabyte invece la leggevo con 
piacere soprattutto in treno. Da 
sempre faccio il pendolare ho que¬ 
sta fortuna/scalogna di dovermi 
servire dei mezzi pubblici. Dato 
che per scelta e per comodità non 
prendo quasi mai la macchina, di¬ 
spongo di una certa quantità di 
tempo da dedicare alla lettura. 

Il sottotitolo della rivista: “CD¬ 


ROM, Shareware-PD, Telematica 
& ALTRO” testimonia la “mission” 
della rivista. 


Il numero di novembre ‘94 si 
presenta con una copertina non 
particolarmente bella ma comun¬ 
que molto ordinata dalla quale si 
evincono facilmente gli argomenti 
“speciali” che la redazione vuo¬ 
le mettere in risalto. Scopriamo 
cosi che possiamo aspettarci uno 
“Speciale Emulatori”, un articolo 
“Source code” sui programmi che 
permettono di costruire facilmen¬ 
te games e una panoramica delle 
tecniche di cattura dello schermo 
mentre sono in funzione altri pro¬ 
grammi: lo “Screen Grabber”. 

A pagina 10 viene spiegato il ser¬ 
vizio “Pegaso” che altro non è che 
una classica BBS ma sul 144. Un 
modo per farsi pagare l’accesso 
insomma! Da come ne parlano, 
giustificandosi ogni tre righe, non 
credo che sia stata una iniziativa di 
successo e quantomeno la reda¬ 
zione deve essere stata subissata 
di proteste. D’altronde, complice 
la SIP, il 144 era identificato come 
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servizio erotico. Vi ricordate le po¬ 
lemiche suirabilitazione automa¬ 
tica dell’acesso? Le associazioni 
dei consumatori vinsero quella 
battaglia e l’accesso venne chiuso 
ma il tutto, pornografia compresa, 
si è trasferito pari pari, sul 166 che 
è abilitato di default. Una classica 
storia di italico disservizio da par¬ 
te delle aziende a partecipazione 
e protezione statale e dei loro di¬ 
rigenti e presidenti pagati a peso 
d’oro (preso dalle nostre tasche 
naturalmente)! 


Molto bello l’articolo sugli emula¬ 
tori, cioè quei programmi che su 
PC ti illudono di avere sotto la ta¬ 
stiera un C64 o uno Spectrum. C’è 
anche l’inverso: il PC emulato su 
un Amiga. Curiosamente sembra 
che la molla principale che spin¬ 
ge a sviluppare ed adottare simili 
software è quella dell’emulazione 
dei giochi. Ho cercato di ricorda¬ 
re quale fosse il livello dei giochi 
su PC, ma sinceramente l’utilizzo 
ludico non è mai stato al primo po¬ 
sto fra i miei interessi informatici. 
Credo comunque che siano stati 


almeno allo stesso livello di quelli 
possibili via emulazione. 

Non solo giochi comunque: quat¬ 
tro pagine sono dedicate alla re¬ 
censione del cd-rom “Il dizionario 
della lingua italiana Devoto-Oli’’. 

Tecnicamente perfetto l’artico¬ 
lo sulla cattura dello schermo, il 
cosidetto “Screen Grabbing”. Bi¬ 
sogna pensare che i programmi 
sono principalmente DOS e quindi 
non ci si può arrangiare con la cli- 
pboard di Windows. Il DOS è no¬ 
toriamente un ambiente mono-ta¬ 
sk e pertanto vanno messi in atto 
una serie di trucchi per “fregare” 
i programmatori che “frappano” la 
routine di input della tastiera sosti¬ 
tuendole con le proprie, soprattut¬ 
to nei programmi “giochi”. 

Completo ed interessante l’arti¬ 
colo che descrive le funzionalità 
del progrmma “Page Plus 3.0”. Si 
tratta di un completo programma 
per il DTP (Desk Top Pubishing) 
funzionante in Windows (versione 
3) che si propone come alternati¬ 
va ai programmi molto più costosi, 
Ventura Publisher in testa. 

Buona parte della rivista è dedi¬ 
cata alla recensione di giochi. È 
evidente che la vocazione “home” 
della pubblicazione non possa 
ignorare quello che è il mercato 
di punta. Il PC viene usato a casa 
moltissimo per i giochi, anzi, a giu¬ 
dicare dai dati di vendita sembra 
che sia l’unico utilizzo “ufficiale” 
delle macchine comperate per 
casa. 
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È strano: si comprano i giochi e 
si copiano i programmi office! Per¬ 
ché? Evidentemente è una que¬ 
stione principalmente di prezzo ma 
non solo. I giochi possono permet¬ 
tersi degli schemi di protezione che 
altri non potrebbero mai addottare; 
si pensi ad esempio all’inserimen¬ 
to di codici diversi ad ogni lancio e 
che si trovano sparsi sulle pagine 
dei manuali. Se Microsoft avesse 
solo tentato una cosa simile si sa¬ 
rebbe auto-esclusa da qualsiasi 
possibilità di fare cassetta con il 
software da ufficio. 


di piacevole lettura, scarse di pub¬ 
blicità, con articoli abbastanza ap¬ 
profonditi. Un vero peccato, ripeto, 
che sia resistita solo qualche anno, 
ma evidentemente i tempi cambia¬ 
no, le mode si evolgono e non ri¬ 
mane altro che pendere atto dei 
cambiamenti, ai quali tutti noi con¬ 
tribuiamo. Un appassionato di tec¬ 
nica e di informatia in particolare, 
non può essere per sua natura un 
reazionario. Il mondo cammina, 
anzi corre! 

[Sn] 


Curioso il software “Klik & Play", 
una sorta di laboratorio per la co¬ 
struzione di giochi. Tramite un’in¬ 
terfaccia abbastanza intuitiva è 
possibile definire il movimento de¬ 
gli “sprite” sullo schermo, le loro 
collisioni, etc... fino ad avere un 
gioco “platform”perfettamente fun¬ 
zionante. Non sò che tipo di suc¬ 
cesso o diffusione abbia avuto un 
simile filone di software, certo che 
leggere le confessioni di chi il sof¬ 
tware shareware ha provato a pro¬ 
durlo .... 


Conclusione 


In definitiva un centinaio di pagine 
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Biblioteca 



La Grande Storia del Computer 


Le monografie 
ì/eccf/e e 
nuove c/ie 
rappresenfano 
una preziosa 
risorsa per c/?i 
ama //mondo 
dei computer in 
genera/e. 


Scheda 

Titolo: La Grande 
Storia Del Computer 

Sottotitolo: 
Dall’Abaco All’Intelli¬ 
genza Artificiale 

Autore: Massimo 
Bozzo 

Editore: Edizioni 
Dedalo (Bari) 

Anno: 1996 

Lingua: Italiano 

Pagine: 250 

Prezzo: € 30,00 i.i. 

ISBN: 

978-88-220-4537-9 




MASSIMO BOZZO 


\ grandi; storia del 

COMPUTER 

Dall’abaco all'Intelligenza artificiale 



l lll/IUM DEDALO 


N on mi trattengo dal dire 
che questa pubblica¬ 
zione dovrebbe essere 
annoverata, almeno per quanto 
riguarda il nostro paese, tra quelle 
di riferimento. Non a caso, spesso 
la si trova citata nelle bibliografie 
di siti e pubblicazioni del settore 
di nostro interesse: il “retrocompu- 
ting”. 

Il libro tratta l’evoluzione delle 
macchine per il calcolo, le tecno¬ 
logie e l’intelligenza artificiale se¬ 
guendo un ordine rigorosamente 
cronologico. Secondo uno sche¬ 
ma classico: suddivisione in ca¬ 
pitoli nei quali viene evidenziato il 
fenomeno che caratterizza il perio¬ 
do e, all’interno di questi, l’elenco 
di vicende e fatti rilevanti elencati 


in base all’anno. Per eventi mag¬ 
giormente rilevanti sono presenti 
delle schede monografiche. Una 
organizzazione elementare, sem¬ 
plice, chiara lo rende simile ad 
una sorta di manuale e consulta- 
bile come tale. 


Eppure, le vere qualità di questo 
libro, quelle cioè che lo rendono 
appunto “di riferimento”, stanno 
nei contenuti e nel modo in cui 
vengono trattati. Queste qualità 
sono in parte esplicitate dall’au¬ 
tore stesso nella premessa: voler 
mantenere un equilibrio tra super¬ 
ficialità aneddotica ed eccesso 
di approfondimento scientifico; e 
non solo queste intenzioni sono 
abbondantemente mantenute, ma 
nonostante l’esposizione in forma 
cronologica, traspaiono pure: stile 
e una grande coerenza d’insieme. 
Sono sicuramente la passione ed 
il mestiere che permettono all’au¬ 
tore di rendere quasi avvincente 
l’esposizione degli eventi anche 
attraverso una struttura piuttosto 
asettica. Infatti, si possono indivi¬ 
duare dei temi portanti che com¬ 
paiono, scompaiono e riappaiono 
lungo tutto lo sviluppo del libro. Si 
tratta probabilmente di quegli ar¬ 
gomenti di rilievo attraverso i quali 
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é stata effettuata la cernita degli eventi da ri¬ 
portare. Però essi sono talmente ben distribuiti 
all’interno della trattazione e vengono così abil¬ 
mente miscelati che costituiscono delle curiose 
trame delle quali si desidera, ad ogni pagina, 
conoscere l’evoluzione. 

Ciò a cui si perviene, pertanto, è un’imma¬ 
gine di assoluto equilibrio e ponderatezza sia 
per il livello della trattazione sia per la varietà 
e modalità di trattazione degli argomenti. Dalle 
origini del calcolo (si parte dalla preistoria!), lo 
sviluppo scientifico, i sistemi di automazione, le 
macchine ma anche lo sviluppo delle diverse 
tecnologie correlate. Ancora: lo sviluppo indu¬ 
striale, la meccanografia, l’elettricità, l’elettroni¬ 
ca. E poi la miniaturizzazione, le ricerche più 
avanzate, i tentativi falliti e quelli di enorme 
successo nell’industria oppure nel sapere. In- 
somma, oltre ad essere sviluppati con coeren¬ 
za gli argomenti portanti sono pure tantissimi e 
tutti interessanti. 

Come può succedere a molti lavori di alto li¬ 
vello essi, paradossalmente, possono sembra¬ 
re perfettibili: si tratta soprattutto di un desiderio 
da parte del fruitore. Infatti, dopo essere stati 
coinvolti e soddisfatti leggendo un lavoro così 
ben fatto, il nostro impulso è quello di volere 
ancora di più, seppure senza sapere in che 
modo. 

Per esempio, sarebbe piacevole un bel grafico 
cronologico curato con altrettanta coerenza e 
precisione (magari che confronti le capacità di 
calcolo delle diverse generazioni di macchine). 
Oppure, non saremmo mai abbastanza soddi¬ 
sfatti dell’egregio repertorio fotografico proprio 
per la sua varietà e originalità: così tanto origi¬ 
nale che ci appare quasi carente solo perché ci 
lascia la voglia di poter averne ancora. Lo stes¬ 
so vale anche per il numero di pagine, che pur 
essendo abbastanza abbondante (e comunque 


250 sono coerenti con la tipologia di edizione) 
sembrerebbe ancora, quasi insufficiente! 

Come è giusto osservare da parte di ogni bi¬ 
bliofilo che si rispetti, è necessaria anche un’ul¬ 
teriore nota di merito rivolta alla qualità dell’edi¬ 
zione: pagine patinate, copertina cartonata ed 
un formato ampio e leggibilissimo ne giustifica¬ 
no il prezzo di copertina. 

Considerando che il libro tratta aspetti di nic¬ 
chia, non credo che gli esiti editoriali di una tale 
pubblicazione siano particolarmente gloriosi; e 
ciò è un peccato! Infatti questo testo riguarda 
lo sviluppo della scienza e della tecnologia in 
generale, ancor prima dell’informatica in parti¬ 
colare. E’ pure un peccato che una così ben 
fatta trattazione di certi argomenti si sia dovuta 
fermare al 1996: sono passati ben dodici anni 
(tecnologicamente è tantissimo!) e sarebbe 
davvero bello sapere, nella stessa maniera e 
dalla stessa persona, come sono continuate 
tutte queste storie che ha voluto raccontarci. 

Infine credo che per noi “retrocomputeristi” 
questo libro possa costituire una sorta di ma¬ 
nuale di riferimento, se non altro per l’ampiezza 
delle vedute in cui inserisce il discorso relativo 
allo sviluppo tecnologico. 

[Jb72] 
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Apple Club 




La mela come 
paradigma della 
programmazione 


Tutti i linguaggi dell ’Apple (13) 


Apple ][ CP/M 
56K Ver. 2.20B 
(C) 1980 Microsoft 


A>dir 


A : 

MUSIMP 

COM 

CONTINUE COM 

TRACE 

MUS 

ARITH 

MUS 

A = 

ALGEBRA 

ARI 

EQN 

ALG 

ARRAY 

ARI 

MATRIX 

ARR 

A : 

SIGMA 

ALG 

LOG 

ALG 

TRGPOS 

ALG 

TRGNEG 

ALG 

A : 

DIF 

ALG 

INT 

DIF 

INTMORE 

INT 

TAYLOR 

DIF 

A : 

LIM 

DIF 

CLES1 

ARI 

CLES2 

ARI 




A>riiusimp 


rnuSIMP-80 2.02 COPYRIGHT (C) 1980 MICROSOFT 
LICENSED FROM THE SOFT HAREHOUSE 

? I 


Mumath/Musimp 

Questa coppia di programmi, che 
si inserisce a buon diritto nell’insie¬ 
me dei linguaggi di programmazio¬ 
ne, sono progettati per la manipo¬ 
lazione simbolica delle espressioni 
matematiche. 


Boot del CP/M e lancio 
del programma muSimp. 
Come si vede il prompt è 
un punto interrogativo. 
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Come diffusione dobbiamo dire 
che ne esistono più versioni, una 
delle quali sotto CP/M per cui è 
disponibile in tutte le piattaforme 
che ospitano un microprocessore 
compatibile (8080 e Z80) e quin¬ 
di anche per Apple II con scheda 
Z80 di Microsoft o compatibile. Per 
preparare questo articolo abbia¬ 
mo considerato proprio la versio¬ 
ne sotto CP/M considerandola più 
“standard” in un certo modo e an¬ 
che perché funziona con display a 


80 colonne e si avvale di tutti quei 
programmi di supporto (ad esem¬ 
pio editor) che ne permettono l’uso 
più agevole. 

A cosa serve un programma di 
calcolo simbolico? Serve! Prima di 
tutto fa la gioia di tutti i liceali alle 
prese con sviluppi in serie, studio 
di funzioni e riduzione di polinomi e 
poi fornisce un aiuto per tutti coloro 
che fanno della matematica un tool 
necessario alla loro professione. 

Inutile ricordare che questi pro¬ 
grammi (abbastanza grezzi per le 
limitate possibilità dei sistemi anni 
80) hanno generato dei veri e pro¬ 
pri mostri come Mathematica e 
Mathcad, tanto per citarne due dei 
più famosi. Questi sono programmi 
che permettono di esplorare le po¬ 
tenzialità della matematica in mo- 
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niera del tutto impensabile fino ad 
allora. 

Prima di tutto facciamo chiarezza 
su che differenze ci sono fra mu- 
Simpe muMath. La sorpresa è che 
in realtà muMath non esiste! O me¬ 
glio: muMath è una “pachetizzazio- 
ne” di funzioni create con muSimp 
e che mettono a disposizione un 
ambiente operativo adatto ad un 
particolare compito di calcolo. Ad 
esempio le radici di un polinomio, 
l’utilizzo dei numero immaginari, il 
calcolo matriciale, etc... 

Poiché le capacità di memoria 
sia RAM che disco sono limitate in 
questi sistemi anni ‘80, si è pensa¬ 
to bene di non costruire un unico 
monolitico programma matemati¬ 
co, ma piuttosto fornire una serie 
di packages con i quali l’utente si 
prepara da solo la versione mu¬ 
Math (o le molte versioni) adatte ai 
suoi scopi di calcolo. 

Il vero linguaggio di programma¬ 
zione è quindi muSimp e noi, an¬ 
che per ragioni di missione, ci con¬ 
centreremo su di esso rimandando 
l’utilizzo del calcolo simbolico via 
muMath ad un’altra occasione. 


Prima di lanciarci nell’esplorazio¬ 
ne delle possibilità del linguaggio, 
conviene che ci rendiamo conto di 
quali sono le possibilità che esso 
offre cariacando in memoria uno 
dei package e usandolo. 

Sul dischetto, assieme all’inter¬ 
prete, troviamo vari file con diver¬ 
sa estensione. MuSimp assegna 
una estensione differente a tipi di¬ 
versi di sorgenti. Ad esempio SYS 
è l’estensione che viene riservata 
al dump dell’intero ambiente, cioè 
al salvataggio completo di tutte le 
definizioni caricate in menoria e 
pronte per un successivo utilizzo. 

ARI, MUS, DIF, ARR, INT, ALG 
sono altre estensioni utilizzate che 
hanno un preciso significato mne¬ 
monico: contengono le iniziali del 
package “padre” di quello salvato. 


Lavorare con muSimp è un po’ 
come giocare alle scatole cinesi: 
si definisce un package che abbi¬ 
sogna del solo muSimp (ed avrà 
estensione MUS), poi si specializ¬ 
za in un package “figlio” che pren¬ 
derà l’estensione dalle iniziali del 
padre, e così via. 


Figura 2. 

Il comando di caricamen¬ 
to del file ARITH.MUS e il 
suo uso nel calcolo razio¬ 
nale. 


La più ecclatante dif¬ 
ferenza fra un linguag¬ 
gio tradizionale e uno 
per la manaipolazione 
simbolica come mu¬ 
Simp, sta nel modo in 
cui vengono rappre¬ 
sentate e manipolate le 
variabili all’interno del 
linguaggio. 


muSIMP-80 2.02 COPYRIGHT (C) 1980 MICROSOFT 
LICEHSED FROM THE SOFT NAREHOUSE 

? RDS (ARITH» MUS)i 

0: ARITH 


? 1/4 + 1/8; 
0 : 3/8 


? I 
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Ad esempio fra la lista dei file 
scorgiamo ARITH.MUS il quale di¬ 
pende da muSimp (MUS sono le 
iniziali del nome muSimp); a sua 
volta il package ALGEBRA.ARI è 
‘‘figlio" di ARITH.MUS e così via. 

E’ chiaro che questa serie di di¬ 
pendenze finisce per essere in¬ 
gestibile o solamente difficile da 
ricordare; è per questo che ad 
un certo punto si fa un bel dump 
dell’ambiente e si mette tutto in un 
file “SYS” e buona notte! 

Con muSimp caricato in memoria 
procediamo a caricare il package 
ARITH.MUS che contiene le fun¬ 
zioni per l’aritmetica (cioè numeri 
interi e numeri razionali). 

Il comando è: 

RDS (ARITH , MUS) ; 

RDS è il comando di caricamen¬ 
to (probabilmente Read...qualche 
cosa), fra parentesi due parametri: 
il nome del file e la sua estensio¬ 
ne, curiosamente definita a parte e 
non con la solita notazione NOME. 
EST. 

muSimp termina i comandi con 
punto e virgola Se non c’è il 
punto e virgola il comando non vie¬ 
ne interpretato al momento di pre¬ 
mere Return. Questo significa che 
si può scrivere tranquillamente una 
espressione su più righe andando 
a capo come se nulla fosse. 

Il comando di caricamento impie¬ 
ga un certo tempo perché ogni de¬ 
finizione nel file da caricare viene 
interpretata e “accomodata” in me¬ 
moria. Arith.mus è un file di testo, 


come ci si può facilmente rende¬ 
re conto eseguendo un TYPE da 
CP/M. 

Dopo il caricamento il sistema tor¬ 
na alprompt (“? “punto interrogati¬ 
vo più spazio) ed emette anche un 
bip, utile per richiamare l’attenzio¬ 
ne qualora ci fossimo dedicati ad 
altro in attesa che l’operazione di 
lettura fosse terminata. 

Arith è un package che permette 
la manipolazione simbolica dei nu¬ 
meri razionali (cioè quelli espressi 
da frazioni di interi). 

Ad esempio: 

? 1/4 + 1/8; 

@ 3/8 

La risposta, preceduta dal sim¬ 
bolo chiocciolina, come si vede 
non è un semplice numero reale 
ma rimane una frazione. Possia¬ 
mo dire, con linguaggio da scuola 
media, che il sistema ha ridotto a 
fattor comune. 

Qualcosa di più difficile: 

? (-24) A (1/3); 

@ -2 * 3 A (1/3) 

Naturalmente l’operatore “ A ” è il 
simbolo dell’elevamento a poten¬ 
za. 

? #E A (1/3) * #E A (2/3) ; 

0 #E 

In muSimp esistono delle costanti 
predefinite. Una di queste è il nu¬ 
mero di Nepero, base dei logaritmi 
naturali #E; un’altra è il Pi greco: 
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? 123! 


1214630436702532967576624324188129585545421798848338231532891816182923589236216 

7668831156960612640202170735835221294047782591091570411651472186029519906261646 

730733907419814952960000000000000000000000000000 


#PI. 

I calcoli numerici sono svolti im¬ 
mediatamente: 


? 3 + 5 
@ 8 

? 5! ; 

@ 125 


5! indica il fattoriale del numero, 
qualcosa che come sappiamo cre¬ 
sce molto ma molto velocemente 
al crescere del numero. Proviamo: 

? 123! ; 

Bhe, il risultato non lo trascrivia¬ 
mo: andate a vedervelo nella fi¬ 
gura in alto. Direi che non c’è da 
scherzare! 

Con questo ultimo calcolo abbia¬ 
mo scoperto una cosa: muSimp 
non è limitato nel range dei numeri 
interi che rappresenta, essi posso¬ 
no essere lunghi a piacere. Ovvia¬ 
mente si dovranno fare i conti con 
la memoria e il tempo per calcola¬ 
re queste quantità particolarmente 
grandi. 

Se si vuole lavorare a livello al¬ 
gebrico, ad esempio alle rappre¬ 
sentazioni di polinomi, è necessa¬ 
rio caricare il package ALGEBRA. 
ARI. Notare che l’estensione è 
ARI, le tre lettere iniziali del packa¬ 


ge che lo precede nella gerarchia, 
cioè ARITH.MUS. 

Dopo il caricamento sono dispo¬ 
nibili una serie di funzioni che per¬ 
mettono la riduzione dei polinomi, 
la ricerca delle radici, etc... 

Un esempio di riduzione è visibile 
nella figura in fondo alla pagina. 

Possiamo dare un’occhiatina 
all’interno del file ARITH.MUS per 
intuire qualcosa della sintassi del 
linguaggio. Essendo un file di te¬ 
sto basta caricarlo con un editor 
(ad esempio Wordstar) o listarlo a 
video con il comando TYPE. 

Ecco una semplice definizione di 
funzione: 


FUNCTION SQUARE (EXl), 
EXl*EXl, 

ENDFUN $ 


La funzione calcola il quadrato di 
un numero che viene passato come 
argomento (EXl). Il risultato è ov- 


Chi ha detto che i numeri 
interi sull’Apple vanno da 
-38676 a + 38678? 


La funzione di trasfor¬ 
mazione frazionaria ap¬ 
plicata ad un polinomio 
di secondo grado in tre 
variabili 


? FCTR(6*X*2*Y -4MIY a 2/22Z); 
2*Ym(-2*Y+3mZ) / z 
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viamente il numero moltiplicato per 
se stesso. 

ENDFUN $ 

chiude la definizione di funzione. 

Una funzione che stabilisce se 
due numeri sono uguali: 

FUNCTION EQ (X, Y), 

WHEN INTEGER (X) AND 
INTEGER (Y), 

ZERO (X-Y) EXIT, 
FALSE, 

ENDFUN; 

La funzione esce con valore 
TRUE se X e Y sono due numeri e 
se sono uguali (la loro differenza è 
zero), oppure esce con FALSE in 
qualsiasi altro caso. 

Come si vede nulla di stravolgen¬ 
te nel linguaggio muSimp rispetto 
ad altri idiomi ai quali possiamo 
essere abituati. Ad esempio che 
conosce il LISP troverà in muSimp 
più di una analogia. 

Infatti anche nelle strutture inter¬ 
ne muSimp assomiglia al LISP; 
magari non è così orientato alle 
liste ma ugualmente immagazzina 
i dati in una lista di puntatori che 
tengono traccia delle varie pro¬ 
prietà dell’oggetto. Ad esempio un 
puntatore (il primo della lista) pun¬ 
ta al valore dell’oggetto, poi trovia¬ 
mo un puntatore al nome, alle altre 
proprietà e alla sua rappresenta¬ 
zione in caso di stampa. 

Un dato in muSimp è classificato 
secondo tre tipologie: è un nome, 
oppure è un numero oppure è un 
nodo. L’entità NOME immagaz¬ 
zina tutti gli oggetti rappresentati 


da un nome simbolico all’interno 
del linguaggio; ad esempio varia¬ 
bili e funzioni. L’entità NUMERO è 
facile capire che si occupa di con¬ 
servare in memoria le proprietà di 
un numero ed infine il NODO è in 
pratica una coppia puntata binaria 
utile a rappresentare strutture dati 
complesse in una forma ad albero 
binario. 

Il NOME sottende in memoria una 
lista di quattro elementi: 

NAME: 

(Value, Property, Function, Pna- 
mes) 

L’entità Pnames è la rappresenta¬ 
zione di stampa cui si accennava 
poco sopra. 

Il NUMERO d’altro canto abbiso¬ 
gna di meno informazioni e la sua 
lista è: 

NUMBER: 

(Value, Sign, Vector) 

In questo caso Vector è il primo 
puntatore ad una lista che con¬ 
tiene gli eventuali elementi di un 
vettore. In muSimp sono definibili 
array multidimensionali e funzioni 
che ne calcolano gli elementi. 

Infine NODE: 

(First, Rest) 

ha una rappresentazione “tipo 
coppia puntata” molto simile al 
LISP Infatti esiste una funzione 
built-in di muSimp che restituisce 
il primo elemento FIRST e una che 
restituisce il resto: REST. 
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Imparare il linguag¬ 
gio muSimp è tutt’al- 
tro che semplice e 
richiede una discreta 
dose di pazienza oltre 
che una conoscenza 
“ferma” delle basi ma¬ 
tematiche. I risultati 
che si ottengono sono 
però all’altezza delle 
aspettative come te¬ 
stimoniano i numerosi 
esempi a complessità 
crescente che sono 
allegati nel package 
muMath. Si arriva fino 
allo sviluppo in serie e 
all’integrazione simbolica! Cose, 
come si vede, tutt’altro che banali. 

Abbiamo accennato all’inizio 
dell’articolo alla presenza di una 
implementazione “nativa” per il 
6502 e quindi proprio di natura 
“applistica”. 

I quattro dischetti che formano 
questa “distribuzione” (fra i quali 
uno vuoto non sono riuscito a ca¬ 
pire perché), portano a bordo un 
sistema operativo diverso dal so¬ 
lito DOS Apple. 

Pensavo inizialmente che fosse 
un caso ma poi ho trovato dei ri¬ 
ferimenti Internet che citano il si¬ 
stema operativo ADIOS-81 come 
modifica al nativo DOS e fatto ap¬ 
posta per distribuire muSimp. 

Inizialmente non sapevo come 
usarli ma poi è bastato reperire un 
piccolo manualino e per quanto ri¬ 
guarda muSimp comportarsi esat¬ 
tamente come nella versione Z80, 


20 

MUSIMP 

COM 

i 

20 

MUSIMPX 

COM 

4 

TRACE 

MUS 

i 

17 

ARITH 

MIJS 

11 

ALGEBRA 

ARI 

i 

2 

EQN 

ALG 

4 

SOLUE 

EQN 

i 

5 

ARRAY 

ARI 

7 

MATRIX 

ARR 

i 

2 

LOG 

ALG 

3 

TRGPOS 

ALG 

i 

4 

TRGNEG 

ALG 

3 

DIF 

ALG 

i 

6 

I NT 

DIF 

8 

IHTMORE 

I NT 

i 

1 

TAYLOR 

DIF 

9 

1 

LIM 

DISKCOPY 

DIF 

COM 

i 

i 

4 

SIGMA 

ALG 


FREE 0N 1 : 

1 > M U SIM P 
1 )RIJN MUSIMP 


1 K-BYTES 


MUSIMP-80 2.15 <03/01/82) 
APPLE IL ADI OS UERSION 
COPYRIGHT <C) 1981 THE SOFT 
LICENSED BY MICROSOFT, INC. 


e le cose sono apparse chiare! 

Nonostante la versione 6202 dia 
l’impressione di essere legger¬ 
mente più veloce, tutto sommato la 
limitazione a 40 colonne del video 
fa propendere le mie preferenze 
per la versione CP/M, anche per 
la presenza di editor e Utilities di 
gestione dei floppy più all’altezza 
della situazione. 

Conclusione. 

Abbiamo esplorato in questo ar¬ 
ticolo un linguaggio di program¬ 
mazione alquanto strano. Un pro¬ 
grammatore “normale” ne sarebbe 
probabilmente inorridito e chi ve¬ 
ramente se lo godrebbe è invece 
il matematico “smanettone” e tutti 
quelli che fanno della curiosità una 
loro dote. 

[Sm] 


UAREHOUSE 


muSimp in versione 
nativa per 6502 sotto 
ADIOS-81, una modifica 
al DOS 3.3 standard di 
Apple. 
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Retro Linguaggi 
|| LISP (pane 3) 


La storia 
deJJinforniatica è 
stata anche Ja storia 
dei linguaggi di 
programmazione. 



Lisp e i processi condizionali 


A ffrontiamo in questa ter¬ 
za puntata l’aspetto della 
valutazione logica delle 
espressioni LISP. 

Come in tutti i linguaggi di pro¬ 
grammazione, anche il LISP im¬ 
plementa la logica booleana per 
valutare i valori di verità di una 
espressione. 

Il valore vero viene esemplificato 
con la parola “true” o anche bre¬ 
vemente “T” (come al solito dipen¬ 
de dal dialetto che si usa). Il vaore 
opposto o falso (ma i puristi della 
logica matematica direbbero “non 
vero”) con “false” o anche NIL, che 
corrisponde al puntatore vuoto. 

Anche gli operatori di confron¬ 
to vengono espressi in notazione 
LISP come liste: 

(equal a b) -> true se ‘a è uguale 
a ‘b; 

(greater a b) -> true se ‘a è più 
grande di ‘b, altrimenti NIL; 


(number a) -> true se ‘a è un nu¬ 
mero; 

(atom a) -> true se ‘a è un atomo, 
NIL se ‘a è una lista; 

(nuli lista) -> true se lista è vuota 
o se l’argomento è NIL; 

(zero a) -> true se ‘a è zero. 

Quelle sopra elencate sono le più 
comuni funzioni booleane presenti 
in LISP. Anche qui, in relazione ai 
dialetti in uso, gli operatori posso¬ 
no trovarsi espressi dai consueti 
simboli: '>' per maggiore, per 
l’uguaglianza, etc... 

Le espressioni booleane sono 
utilizzate nel flusso condizionale 
del programma. In LISP esiste la 
funzione COND che restituisce un 
certo valore in base ad una lista di 
possibilità selezionate tramite con¬ 
fronti. 

Ad esempio definiamo la funzio¬ 
ne max che restituisce il più gran¬ 
de fra due numeri: 

(defun max (a b) 

(cond 

((greater a b) a) 

(true b) 

) 

) 

Nella funzione COND in pratica si 
elencano le possibili scelte con una 
sitassi del tipo (condizione risulta¬ 
to). la valutazione avviene parten- 
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do dall’alto. Quindi ad esempio: 
(max 3 2) -> 3 
(max 2 3) -> 3 
(max 3 3) -> 3 

La sintassi (true b) indica una con¬ 
dizione sempre vera e quindi se la 
valutazione arriva fino a quel pun¬ 
to, il risultato della funzione è il pa¬ 
rametro che segue il valore true. 

Una piccola variazione sul tema 
della funzione max. Supponiamo 
di volere un risultato pari a 0 qua¬ 
lunque siano i due numeri passati 
come paramentri, se i due nume¬ 
ri sono uguali. La soluzione è che 
dobbiamo semplicemente aggiun¬ 
gere una condizione (in testa alle 
altre) che ci permetta di controllare 
questo caso speciale: 

(defun max (a b) 

(cond 

((equal ab) 0) 

((greater a b) a) 

(true b))) 

Un’altro uso “classico” delle fun¬ 
zioni condizionali è quello che per¬ 
mette di trattare grandezze non 
definibili come numerosità a priori. 
Ad esempio si consideri il seguen¬ 
te problema: -”si scriva una funzio¬ 
ne LISP che restituisca l’ultimo ele¬ 
mento di una lista data della quale 
non si conosce a priori la lunghez¬ 
za’’. 

Quello che dobbiamo fare per ri¬ 
solvere questo esercizio è iterare 
la funzione CDR fino a giungere 
ad una lista di un solo elemento, 
che sarà appunto l’ultimo elemento 
della lista sorgente. 


(defun last (lista) 

(cond 

( (nuli (cdr lista)) (car 
lista)) 

((last (cdr lista))) 

) 

) 

L’analisi è la seguente: nella prima 
condizione esaminata dalla COND 
si trova la cosidetta “condizione di 
uscita”, soggetto tipico della pro¬ 
grammazione ricorsiva. Se il CDR 
della lista è vuoto, allora l’ultimo 
elemento della lista è il suo CAR 
e siamo arrivati alla fine. Se non è 
così, per trovare l’ultimo elemento 
ri-applichiamo la funzione LAST 
ma ad una lista più piccola: quella 
senza il CAR. 

Per la sua natura funzionale il 
LISP si presta molto bene ad im¬ 
plementare la ricorsione, cioè a 
quella tecnica di programmazio¬ 
ne, ma anche di calcolo aritmeti¬ 
co, che consiste nell’applicare una 
funzione al risultato parziale della 
stessa per arrivare alla condizione 
elementare che può essere risolta 
in modo banale. 

Vediamo un’altro esempio di uti¬ 
lizzo della funzione di selezione 
COND, questa volta applicata ad 
un problema di ricerca di un ele¬ 
mento in una lista originale. Cioè 
qualcosa per cui ad esempio: 

(member ‘a ‘(b c d a)) -> true 

(member ‘a ‘(b c d)) -> NIL 

Si tratta di “andare a cercare l’ele¬ 
mento ‘a all’interno della lista ed 
uscire alla prima occorrenza, op¬ 
pure arrivati in fondo desistere con 
un bel NIL. 
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(defun member (a lista) 

(cond 

((nuli lista) NIL) 

((equal a (car lista)) 

true)) 

( true (member a (cdr 
lista))) 

) 

) 

Anche nella definizione della fun¬ 
zione MEMBER abbiamo fatto uso 
della ricorsione, richiamando la 
funzione su se stessa ma ovvia¬ 
mente (regola fondamentale) su 
un insieme più piccolo. 

Classico e immancabile l’esempio 
della definizione della funzione fat¬ 
toriale. Come sapete certamente, 
ma lo ripetiamo per completezza, 
si definisce fattoriale del numero N 
il risultato dell’operazione: 

Fattoriale(N) = N * Fattori a le (N - 

V 

Come dire: Fattoriale(5) = 5*4* 
3*2*1 

Con la condizione di limite: Fatto¬ 
riale (0) = 1, altrimenti il fattoriale di 
qualsiasi numero sarebbe sempre 
zero! 

La definizione in LISP è sempli¬ 
ce: 

(defun fattoriale (n) 

(cond 

((zero n) 1) 

(true (fattoriale (sub n 

1 ))) 

) 

) 

Attenzione: è molto facile sfonda¬ 
re lo stack, soprattutto su macchi¬ 
ne retro, quando ci si fa prendere 
la mano con la ricorsione! 

Per terminare questa terza parte 
del corso facciamo una breve ras¬ 
segna di altre funzioni che lavora¬ 


no su stringhe e numeri e che im¬ 
plementano utili pezzetti di codice 
da usarsi eventualmente nei nostri 
programmi. 

Calcolare la lunghezza di una li¬ 
sta. 


(defun len(lista) 

(add L 1) 

(cond 

((equal (car lista) NIL) 'L) 
(true (len (cdr lista))) 

) 

) 

Questa forma di calcolo della lun¬ 
ghezza di una lista non è proprio 
“pulita”. Il problema è che abbiamo 
fatto due ipotesi che potrebbero 
anche non rivelarsi vere. La prima 
è che la variabile L non sia usata 
nell’environment, cioè non sia sta¬ 
to definito un atomo assegnando 
ad esso un valore; la seconda ipo¬ 
tesi è che la lista non deve essere 
vuota, altrimenti il risultato sareb¬ 
be comunque 1, il che ovviamen¬ 
te non è proprio il massimo della 
correttezza. 

Dobbiamo disporre di “variabi¬ 
li loocali”, come si direbbe in altri 
linguaggi e forse è più opportuno 
usare una implementazione itera¬ 
tiva per calcolare la lunghezza di 
una lista. 


(defun len(lista) 

(prog (L X) 

(set L 0) 

(set X lista) 

LOOP 

(cond 

((nuli X) (return L)) 
(true (set L (add 1 


) 

) 

(go LOOP))) 
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Abbiamo introdotto il goto, ebbe- Alla prossima, 
ne sì, LISP ne fa uso, al pari del 
BASIC non strutturato. Nella defini¬ 
zione prima di tutto la dichiarazione 
“prog” sta a significare che da quel 
punto parte un codice “locale” con 
due variabili L e X. La prima cosa 
che si fa entrando è instanziare 
queste due variabili rispettivamen¬ 
te a zero, per iniziare il contatore 
dio lunghezza, e alla lista sorgente. 

Poi X come lista sarà “decapitata” 
ad ogni iterazione. 

Successivamente troviamo la 
parola isolata LOOP. Questo è un 
nome di una label e serve solo 
come riferimento per le istruzioni di 
salto. 

La condizione successiva è l’al¬ 
goritmo che calcola la lunghezza 
iterando la parte finale della lista 
fino a che la lista stessa (variabile 
X) non risulta vuota, cioè la condi¬ 
zione finale con restituzione del va¬ 
lore L (istruzione RETURN). Infine 
l’istruzione di salto che in LISP ha 
questa sintassi: 

(GO <label>), dove <label> indica 
il nome del ”bookmark” da dove ri¬ 
prendere l’esecuzione. 


Nella prossima lezione faremo la 
conoscenza con altre importanti 
funzioni di base per la manipola¬ 
zione delle stringhe e delle liste. In 
LISP è possibile trasformare una 
stringa in una lista di caratteri e vi¬ 
ceversa... ma non anticipiamo trop¬ 
po. 


[Sm] 
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Emulazione 


Imondi virtuali 
a volte possono 
essere molto 
realistici... 


Figura 1. 

La copertina della pubbli¬ 
cazione. 


ZX Spectrum on your PC 



THE 

ZX SPECTRUM 
ON YOUR PC 

Emulators, 

Utilities and more 




flirt 


O ccasione ghiottissima 
per gli ex possessori 
della macchina vintage 
forse più amata, lo Spectrum della 
Sinclair, per riavvicinarla attraver¬ 
so l’emulazione sui moderni PC 
da scrivania. 

Può darsi che a molte persone, 
antichi e presumibilmente felici 
possessori del capolavoro di sir 
Olive Sinclair, non abbiano trova¬ 
to occasione o semplicemente il 
tempo e la voglia di mettersi ad 
approfondire il discorso sull’emu¬ 
lazione. Sembra tutto così natu¬ 
rale per noi che pratichiamo l’arte 
(perché di vera e propria arte si 


tratta) dell’emulazione, l’installare 
le innumerivoli beta dei vari pro¬ 
getti alla ricerca di quella “emula¬ 
zione perfetta’’ o come era moda 
dire qualche anno fa “della madre 
di tutte le emulazioni”. Non va ne¬ 
gato che un minimo di studio è ri¬ 
chiesto quando si decide di adot¬ 
tare uno di questi programmi: la 
corrispondenza dei tasti, i frame 
per secondo da regolare, il suono 
sì e il suono no, e per finire le im¬ 
magini di dischi e cassette. 

Personalmente ho sempre tro¬ 
vato molto interessante qualsiasi 
tentativo di portare il comporta¬ 
mento di un sistema su un’altro di 
pari o maggiore potenza. E’ un po’ 
come una “probazione assistita”, 
se mi passate il termine. Ora poi 
con la potenza dei PC che abbia¬ 
mo sotto le dita, mai come adesso 
inutilizzata, non provare l’emozio¬ 
ne dell’emulazione suona quasi 
blasfemo! 

Colin Woodcock deve pensarla 
alla stessa maniera dal momento 
che è l’editore e uno degli anima¬ 
tori del sito ZXF, una fanzine dedi¬ 
cata allo ZX Spectrum [1] e un sito 
prezioso per tutti gli appassionati 


[1 ] http://zxf.magazine.googlepages.com/home 

[2] http://www.lulu.com/product/libro-a-copertina-morbida/the-zx-spectrum-on-your- 
pc/5595757 
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del computer con l’arcobaleno. 

Mantenendo fede alila propria 
missione anche il volume è prele¬ 
vabile liberamente dal sito, oppure 
si può ordinare in edizione stam¬ 
pata (per chi ha posto) dal sito del 
servizio LULU [2] . 

Il volume affronta in maniera or¬ 
ganica il progetto di portare uno 
ZX Spectrum su un PC attraverso 
l’adozione di uno degli emulatori 
disponibili sul Web. 


queste “aggiunte” andrebbero evi¬ 
tate. 

La preferenza dell’autore va 
all’emulatore Spectaculator, ma le 
possibilità sono molte, comprese 
quelle che riguardano altre piatta¬ 
forme (MAC e Linux). 

Per finire l’autore ha pensato 
bene di accennare per completez¬ 
za e anche per invitarne l’uso, al 
gruppo Usenet dedicato alla mac¬ 
china [3] 


Gli argomenti partono dalle basi 
dell’emulazione, proseguono con 
l’argomento della reperibilità dei 
programmi (le famose immagini) 
per lanciarsi poi verso argomenti 
più sofisticati quali l’emulazione 
delle periferiche (stampante e mi¬ 
crodrive la fanno da padroni). 

Utile il riassunto sulle varie relea- 
se e sulle macchine Spectrum-Li- 
ke che sono uscite nei quasi dieci 
anni in cui il sistema è rimasto in 
voga e sull’utilizzo dello stesso e 
delle periferiche dal punto di vista 
dell’utente. 

Non si parla di programmazione, 
non avrebbe senso in un contesto 
dove principalmente si emula per 
giocare, ma le possibilità ci sono 
ovviamente tutte. 

Concludono le 82 pagine del 
volume la panoramica sui cloni 
di origine russa e sul TR-DOS, il 
sistema operativo che aggiunge 
notevoli capacità di gestione allo 
Spectrum, anche se per i puristi 


[3] comp.sys.Sinclair 


Conclusioni. 


Questo testo mi è piaciuto pa¬ 
recchio: è curato, mai banale e si 
intuisce l’impegno che ne è stato 
profuso. Personalmente ritengo 
sia un volume destinato a durare 
a lungo e, magari con opportu¬ 
ni aggiornamenti, accompagnare 
i neofiti dell’emulazione o dello 
Spectrum alla scoperta di questo 
fantastico mondo virtuale e di que¬ 
sta fantastica macchina. 

[L2] 


Figura 2. 

Una delle pagine ricche 
di informazioni riassu¬ 
me i passi necessari per 
convertire un file imma¬ 
gine in una cassetta au¬ 
dio reale. 


ZX Spectrum on youi PC 


Walk through: Convorting 
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TAMC 


Algoritmi di SORT (parte 6) 


Teoria e 
Applic,azioni 
delie Macchine 
Calcolatrici: Ja 
matematica e 
J informatica, 
le formule e gli 
algoritmi, la 
completezza e la 
computabilità, 
le strutture dati 
e tutto quello 
che sta alla base 
dell informatica. 


Counting Sort 

F inora gli algoritmi che ab¬ 
biamo esaminato sono 
costruiti su un’unica ipote¬ 
si, cioè che il vettore da ordinare 
sia costituito da numeri interi sen¬ 
za altro vincolo. 

Abbiamo annunciato che guesta 
proiezione del problema realizza il 
principio di equivalenza algoritmi¬ 
ca, cioè che se l’insieme da ordi¬ 
nare non è più un vettore di interi 
ma qualsiasi altra tipologia di dato, 
la complessità algoritmica rimane 
la stessa. 

Per la verità, se ci pensiamo, dire 
che stiamo ordinando un insieme 
di interi su un computer ha di per 
se una limitazione: i valori sono 
compresi nel range rappresenta¬ 
bile dalla macchina nel particolare 
linguaggio che abbiamo deciso di 
adottare per la codifica. Questo 
non ci ha preoccupati, dal momen¬ 
to che teoricamente è possibile 
rappresentare numeri interi come 
sequenza, teoricamente infinita, di 
cifre. Cambierà il tempo di esecu¬ 
zione, lo spazio di memoria, etc... 
ma non la complessità algoritmi¬ 
ca. 

Dove vogliamo arrivare con que¬ 
sta lunga premessa? Al fatto che 


se si conosce qualche caratteristi¬ 
ca a priori dell’insieme da ordinare, 
allora si possono studiare algoritmi 
che traggano vantaggio da questa 
conoscenza intrinseca. 

Un esempio è il Counting Sort, 
algoritmo di ordinamento che as¬ 
somma due caratteristiche note¬ 
voli: è semplice da implementare 
e raggiunge una efficienza sor¬ 
prendente: O(n) anche nel caso 
più sfortunato. 

Counting sort è applicabile in un 
caso specifico e cioè con l’ipotesi 
aggiuntiva che i valori contenu¬ 
ti nell’insieme da ordinare siano 
paragonabili in grandezza alla di¬ 
mensione N del vettore. 

In altre parole: se N è il numero di 
elementi del vettore da ordinare e 
se tutti i valori sono inferiori ad una 
certa soglia S, dove S è all'incir¬ 
ca uguale a N, allora si cade nella 
ipotesi necessaria all’applicazione 
del Counting sort. 

L’idea che sta alla base dell’algo¬ 
ritmo è la seguente: dal momento 
che sappiamo che un elemento p 
del vettore sta nel range di valori 
[0..S], ci saranno più o meno p ele¬ 
menti minori di p e quindi una buo¬ 
na posizione di partenza per p nel 
vettore ordinato sarà la posizione 
(P + 1)- 


52 





















E’ chiaro che questo primo pas¬ 
saggio non può essere sufficien¬ 
te a restituire un vettore ordinato, 
a meno che il set di valori non sia 
proprio il sottoinsieme dei naturali 
[0...N]. 

Servono altri passaggi e anche 
due aree di appoggio, quindi mol¬ 
ta memoria, ma ogni “giro” di raffi¬ 
namento è lineare e pertanto con¬ 
serva la complessità di ordine N, 
senza esplodere al crescere del 
numero di elementi. 

L’informazione, che possiamo de¬ 
finire di cardinalità, dell’insieme di 
partenza, si sfrutta estendendola 
ai sottoinsiemi dello stesso. Cioè si 
fa il ragionamento seguente: se p 
è un numero appartenente al vet¬ 
tore da ordinare e abbiamo ipotiz¬ 
zato che la sua posizione finale sia 
più o meno all’indice (p+1), allora 
possiamo costruire un vettore che 
contenga per ogni indice il numero 
di elementi che lo precedono nel¬ 
la posizione. La cardinalità viene 
sfruttata per costruire un’area di 
appoggio all’ordinamento che sia 
a sua volta ordinata, cioè si lavora 
su una meta-conoscenza piuttosto 
che sulla conoscenza vera che sa¬ 
rebbero i reali valori nell’insieme. 

Se si aggiungono vincoli di cono¬ 
scenza del vettore di partenza, ad 
esempio se si suppone che tutti i 
valori sono diversi e sono nel ran- 
ge 1..N, allora è chiaro che l’ordi¬ 
namento si riduce a spostare nella 
giusta posizione del vettore ordina¬ 
to l’elemento il cui valore è anche 
l’indice stesso. 
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Counting Sort 


3 5 7 1 4 6 2 


8= 0 2 0 0 0 0 0 


B = 0200060 

"WT 

B=02O4060 


B = 1204060 


B = 1 2 0 4 0 6 7 

C=0133557 

B = 1 2 0 4 5 6 7 

C = 0133556 

B = 1 2 3 4 5 6 7 

C = 0133456 

1 2 3 4 5 6 7 



L’esempio che abbiamo usato 
nelle ultime lezioni (Mergesort e 
Heapsort) aveva proprio questa 
caratteristica, essendo un insieme 
dei primi sette numeri naturali sen¬ 
za ripetizioni: 


Figura 1. 

L’andamento di formazio¬ 
ne del vettore ordinato B 
e del vettore ‘‘counting’’ C. 


[3, 5, 7, 1, 4, 6, 2] 


Il vettore ordinato è ovviamente: 


[1, 2, 3, 4, 5, 6, 7] 


Per ottenerlo basta semplicemen¬ 
te prendere un elemento del vetto¬ 
re di partenza, ad esempio il primo, 
e lo si sposta nella posizione corri¬ 
spondente al suo stesso valore: 


[0, 0, 3, 0, 0, 0, 0] 


e così via. 


L’idea del Counting Sort è proprio 
la stessa, solo che è necessario 
un vettore di conteggio per rende- 
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Program sortcount; 
var 

A, B : array[1..7] of integer; 
C : array[0..7] of integer; 
i, k, n : integer; 


begin 


A[l] 

= 3; 

A[2] 

= 5; 

A[3] 

= 7; 

A[4] 

= i; 

A[5] 

= 4; 

A[6] 

= 6; 

A[7] 

= 2; 

n :=' 

0 


k := 7; 

writeln(‘Counting Sort’); 

writeln; 

wrlteln; 

writeln(A[l], A[2], A[3], A[4], A[5], A[6], A[7]); 

writeln (‘================’); 

{ primo ciclo } 

for i:= 0 to k do C[i] := 0; 

{ secondo ciclo } 

for i:= 1 to n do C[A[i]] := A[i]; 


cazione di valori all’interno del set 
da ordinare, dovremmi aggiun¬ 
gere un ulteriore ciclo ai quattro 
presenti. Abbiamo deciso di non 
spingerci a tanto per non sporca¬ 
re la percezione della semplici¬ 
tà di questa implementazione e 
perché ci interessava soprattutto 
ribadire che quando si affronta 
un problema di ordinamento o 
anche un problema informatico in 
generale, la conoscenza dei vin¬ 
coli e delle condizioni al contorno 
determina a volte una semplifica¬ 
zione drastica dell’algoritmo e di 
conseguenza una maggiore effi¬ 
cienza e velocità di codifica. 


{terzo ciclo } 

for i := n downto 1 do begin 
B[C[A[i]]] := A[i]; 

write(‘B = % B[l], ‘ B[2], ‘ % B[3], ‘ B[4], ‘ B[5], ‘ B[6], ‘ % B[7], 
‘i‘); 

writeln(‘C = C[l], ‘ C[2], ‘ C[3], ‘ C[4], ‘ % C[5], ‘ % C[6], ‘ 
C[7]); 

C[A[i]] := C[A[i]] -1; 
end; 

{ quarto ciclo} 

for i := 1 to n do A[i] := B[i]; 

writeln (<================’); 

writeln(A[l],“,A[2],“,A[3],“,A[4],“,A[5],“,A[6],“,A[7]); 

readln; 

end. 


re l’algoritmo più flessibile, dato 
che non accettiamo la banalità 
dell’esempio analizzato. 

Nel listato riportato in questa pa¬ 
gina abbiamo la codifica nel soli¬ 
to Borland Pascal 7.0 sotto DOS 
(perché scomodare dava? :-). 


Il cuore vero dell’algoritmo è il 
loop che costruisce il vettore di 
conteggio. Per adattarlo a tutti i 
casi, compreso quello della dupli- 


Bucket Sort 

Dall’algoritmo Counting sort 
abbiamo imparato che qualora 
l’insieme dei valori da ordinare 
sia ‘‘non troppo cattivo”, allora 
si possono fare semplificazioni 
notevoli, facciamo il seguente ra¬ 
gionamento: supponiamo che un 
insieme di N elementi apparte¬ 
nenti ai numeri naturali tali che ri¬ 
esimo elemento sia tale che ogni 
valore sia compreso nel range 
1<n<T. Facciamo inoltre l’ipotesi 
che all’interno del sistema da or¬ 
dinare gli elementi siano uniforme- 
mente distribuiti, cioè che si possa 
dividere l’intervanno in k ‘‘cestini” 
inserendo gli elementi che sono 
limitati nel range previsto per ogni 
bucket. L’uniforme distribuzione 
degli elementi assicura che nei k 
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bucket finiranno pochi elementi. 

A questo punto si possono isola¬ 
re questi sottoinsiemi e procedere 
al loro ordinamento utilizzando un 
algoritmo efficiente su insiemi pic¬ 
coli e successivamente procedere 
con il “merge’’ di questi sacchettini 
di valori che risultano già a posto 
dal punto di vista dell’operazione di 
ordinamento. 

Si tratta quindi di un algoritmo che 
prende vantaggio dalla preesisten¬ 
te ipotesi di riuscire a costruire dei 
sottoinsiemi trattabili con poca di¬ 
spersione di risorse. 


La predisposizione dei bucket e il 
loro riempimento è evidentemen¬ 
te una operazione lineare, cioè di 
ordine N, così come l’algoritmo di 
ordinamento che si applicherà ai 
singoli bucket, come si avrà l’ac¬ 
cortezza di scegliere. Risulta infine 
che il Bucket Sort ha 0(n 2 ) anche 
nel caso più sfavorevole. 


Riportiamo l’algoritmo in una 
pseudo-codifica: 


BUCKETSORTf A, n, s , t ) 

Sia l’insieme A [1..n] il vettore da 
ordinare, seti limiti inferiore e su¬ 
periore della distribuzione dei valo¬ 
ri degli elementi di A. 

Si divida il range 1..N in k elemen¬ 
ti B (bucket) k = (s-t)/n 

Per ogni elemento di A inserirlo 
nel Bucket giusto B . 
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Per ogni Bucket si proceda ad un 
ordinamento utilizzando ad esem¬ 
pio un InsertSort. 

Sostituire gli elementi di A con la 
sequenza ricavata dai k Bucket: 


Conclusione 

Siamo così giunti alla conclusione 
del nostro mini viaggio fra i princi¬ 
pali algoritmi di ordinamento che si 
utilizzano normalmente nell’ambito 
applicativo. 

Così come abbiamo mostrato in 
questa puntata conclusiva, per pro¬ 
cedere con qualcosa di diverso dai 
classici ormai consolidati, è neces¬ 
sario fare delle ipotesi sul vettore di 
elementi da ordinare. Sono neces¬ 
sarie cioè delle meta-conoscenze 
per attivare la strategia migliore nei 
confronti del problema che si inten¬ 
de affrontare. 

Questa situazione è comune 
nell’ambito dell’informatica e chi 
ci lavora o intende farne la propria 
professione, ne incontrerà parec¬ 
chie di queste situazioni. 


Buon proseguimento a tutti. 


[Sm] 
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Retro Software 



Non solo l’hardware 
ha segnato la sto¬ 
ria dell’informatica 
personale, ma e 
soprattutto il softwa¬ 
re, il motore dei tanti 
sistemi che ci hanno 
accompagnato alla 
scoperta di questo 
fantastico mondo. 


Borland Turbo Prolog LO 



- Turbo Prolog - 

Copyright (c) 1986 
Borland International 
TURBO PROLOG version 1.0 


- Configuration - 

Work file WORK.PRO 

PRO directory A A 

OBJ directory A: 

EXE directory A A 

Turbo directory CATPRO10 
DOS directory A A 




Minimalista lo splash 
screen al primo lancio 
dell’ambiente. Ci ricorda 
che dobbiamo settare le 
variabili di environment. 


O ggi vogliamo cimentar¬ 
ci con un linguaggio di 
programmazione che 
ha visto un periodo di inaspettata 
popolarità attorno alla metà degli 
anni ’80 ma che poi è rapidamente 
caduto nel dimenticatoio. 

Il grande fermento nell’evoluzio¬ 
ne dei linguaggi di programma¬ 
zione seguito dalla disponibilità 
diffusa delle piattaforme personal 
per il calcolo automatico, generò 
tutta una serie di tentativi ed errori 
tesi principalmente al superamen¬ 
to delle idiosincrasie insite nella 
sintassi del BASIC, linguaggio di 
elezione delle piattaforme home e 
personal delle prime generazioni. 

L’impulso dato a questo compar¬ 
to dalla comparsa del pc a basso 


prezzo è stato altissimo, complice 
anche la potenza elaborativa che 
andava crescendo di generazione 
in generazione e dall’approcciarsi 
alla teoria da parte di moltissimi ri¬ 
cercatori a livello mondiale. 

Prolog sembrò avere quel tocco 
di magia che permetteva di slegare 
la descrizione di un problema dalla 
sua codifica a livello di linguaggio 
formale. Cioè: abbiamo un proble¬ 
ma, lo descriviamo e lasciamo che 
sia la macchina a trovare la stra¬ 
da per risolverlo. Affascinante e 
ovviamente incline all’idea di una 
“Intelligenza Artificiale” nascosta 
da qualche parte nei chip e che 
andava semplicemente svelata, 
mentre nessuno dubitava della 
sua esistenza. Una sorta di fede 
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quindi, una convinzione che ba¬ 
stava trovare l'approccio giusto 
e improvvisamente quel mucchio 
di ferraglia si sarebbe trasformato 
come d’incanto in una macchina 
intelligente! 

Anche la Borland, conosciutissi¬ 
ma ed apprezzata software house 
produttrice dei compilatori “Turbo”, 
si fece attirare da un mercato di 
nicchia ma con buone prospettive 
di crescita e fece uscire dal suo 
cappello a cilindro una implemen¬ 
tazione del Prolog che a buona 
ragione venne appellato con l’ag¬ 
gettivo di “Turbo”. 



Il prodotto 


Prima operazione: 
settore le directory. 


E in effetti il prodotto rimane fe¬ 
dele alla filosofia aziendale distac¬ 
cando anni luce la concorrenza sul 
fronte della velocità di esecuzione. 
Borland poi fece tesoro della sua 
esperienza negli environment di 
programmazione corredando an¬ 
che il Prolog di quelle features in¬ 
tegrate che tanto servizio stavano 
rendendo al Pascal e al C dal punto 
di vista degli strumenti di sviluppo. 

Per raggiungere l’efficienza il Tur¬ 
bo Prolog sacrifica qualche cosa 
allo standard: prima di tutto si 
“dialetizza”, prende cioè una stra¬ 
da diversa per la sintassi rispetto 
al Prolog “ufficiale” che era quello 
dell’università di Edinburgo, poi 
chiamato “Edinburgh Prolog”. La 
limitazione più importante non è 
comunque questa, ma piuttosto il 
pegno che Turbo Prolog paga per 
effetto della compilazione alla va¬ 
lutazione delle clausole dinamiche 
(vi spiego dopo cos’è una clauso¬ 
la). 


Non è difficile procurarsi la verione 
1.0 o la successiva 1.1 in rete. Non 
sono sicurissimo che sia stato rila¬ 
sciato free da Borland, ma sicura¬ 
mente per uso personale nessuno 
verrà mai a contestarvi di averne 
una copia in casa! Fra l’altro un’al¬ 
tra azienda, la Prolog Development 
Center (PDC) ne ha rilevato i diritti 
di sviluppo e produce un Visual 
Prolog (vedi bibliografia per i riferi¬ 
menti), con anche una versione 
“personal” priva di licenza. 

Turbo Prolog 1.0 viene rilasciato 
su un’unico Floppy da 5,25”ad alta 
densità e occupa circa 400 Kb una 
volta installato su hard disk. L’am¬ 
biente funziona anche su un siste¬ 
ma a due floppy, nel cui caso il file 
READ ME consiglia come dividere 
i file fra i due supporti in modo da 
avere in linea il compilatore e con¬ 
temporaneamente poter disporre 
di spazio su disco per lo sviluppo 
dei programmi. 
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j]^ Compile Edit Options Files Setup Quit 

VA Unv. nui 1 

LéW 1 LUI 

v la luy 


Goal : parent(maria, Y). 

Y=gesu 

1 Solution 

Goal : 

/* esempio 001 */ 

domains 

persoli = Symbol 

predicates 

parent(person, person ) 

clauses 

parent(maria, gesu). 
parent(giuseppe, gesu ). 



1 

i icòòayc 

Load ES001.PRO 

Compiling ES001.PRO 
parent 

■ 

’8:Previous line F9:Edit S-F9:Uieu uindous S-F10:Resize uindou Esc:Stop exec| 


Esiste l’applicativo INSTALL.EXE 
ma è anche sufficiente copiare i file 
in una directory del disco C: e poi 
eseguire l’applicativo PROLOG. 


EXE (di circa 200 KB) per trovarsi 


nell’ambiente di sviluppo. 




comunque in linea con quello al 
quale eravamo abituati anche con 
altri prodotti. Anche la dimensione 
utile per le finestre non è proprio 
il massimo, comunque le finestre 
dei messaggi e di trace si possono 
chiudere per avere maggiore spa¬ 
zio per l’editor e l’esecuzione. 

La compilazione può avvenire in 
memoria oppure produrre un file 
oggetto (estensione OBJ) o diret¬ 
tamente un eseguibile (estensio¬ 
ne EXE). Produrre un eseguibile 
comporta aver progettato un pro¬ 
gramma che non si aspetta una in¬ 
terattività utente, mentre l’uso più 
normale di un programma Prolog 
è l’esplorazione delle risposte a 
fronte del db della conoscenza ac¬ 
quisito dai fatti e dalle regole. 


La prima cosa da fare è passare 
per il Setup e configurare le direc¬ 
tory ed eventualmente i colori delle 
varie finestre che formano l’envi- 
ronment. Il funzionamento è il se¬ 
guente: nella finestra Editor (rag¬ 
giungibile dalla voce “Edit” sul 
menù) abbiamo il file in sviluppo 
che di default si chiama “WORK. 
PRO”. La finestra Dialog è la parte 
interattiva, dove l’utente inserisce 
le domande che pone al sistema; 
poi abbiamo una window per i 
messaggi e una di trace. 

Il mouse non è supportato per cui 
ci si deve arrangiare con la tastiera 
e gli eventuali tasti funzione. L’in¬ 
terazione con l’ambiente ne risulta 
un po’ appesantita dal continuo ri¬ 
corso al tasto Escape, ma siamo 


Turbo Prolog è un compilatore, il 
che significa che si predispone un 
sorgente, lo si compila e lo si man¬ 
da in esecuzione. Un programma 
Prolog però non è come un classi¬ 
co programma che è in esecuzione 
dalla prima istruzione attraverso il 
flusso predisposto dal program¬ 
matore. Qui si tratta di compilare 
una serie di fatti e di regole, che 
poi sono la “conoscenza” del siste¬ 
ma in un certo contesto, poi in ma¬ 
niera interattiva si pongono delle 
domande peravere le conseguenti 
risposte. 

Nelle figure che corredano l’arti¬ 
colo un semplice esempio. Abbia¬ 
mo tre sezioni: 


58 




















Jurassic News - Anno 5 - numero 28 - marzo 2010 


“domains” dove si dichiarano le 
variabili 

“predicates” che contiene le rego¬ 
le di deduzione 

“clauses” che è il database delle 
conoscenze. 

In questo semplice esempio ispi¬ 
rato al Natale, abbiamo la dichia¬ 
razione di “person” come variabile 
(syrnbol significa che assumerà un 
valore nel programma); la regola 
è che per essere parent bisogna 
che ci siano due persone, eviden¬ 
temente; infine le clausole che sta¬ 
biliscono dei fatti. Qui vediamo che 
gesù (le costanti in Prolog si di¬ 
chiarano con le lettere minuscole, 
mentre le maiuscole sono riservate 
alle variabili) ha due genitori: maria 
e giuseppe (senza sottilizzare trop- 
po :-)) 

Dicevamo che Prolog da delle ri¬ 
sposte e lo fa agendo sui predicati; 
possiamo chiedere ad esempio: 

parent(X, gesu) 

per avere due soluzioni per la va¬ 
riabile run-time X: maria e giusep- 
pe. 

Peraltro si potrebbe anche chie¬ 
dere: 

parentfmaria, Y) 

per avere come risposta gesu. 


Queste domande che vengono ri¬ 
volte al sistema si chiamano in ger¬ 
go “goal” che sta ad indicare l’idea 
che il sistema cerca di soddisfare il 
predicato basandosi sulle clausole 
ad esso conosciute e che possono 



anche incrementarsi a run-time. 


Il funzionamento di un sistema 
Prolog è basato su un principio te¬ 
orico studiato dal logico John Alan 
Robinson nel 1965 che andava 
cercando un metodo matematico 
per rappresentare gli assiomi della 
logica dei predicati. Il suo principio 
dice in pratica che si può ridurre 
una clausola in forma normale, 
chiamata “forma di Horn” e che esi¬ 
ste un metodo meccanico in grado 
di dare delle risposte di verità (se 
esistono). 

Non è il caso di approfondire 
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/* Esempio numero 13*/ 

domains 

title,author = Symbol 
pages = integer 
publication = bookftitle,pages) 

predicates 

written_by(author,publication) 
long_novel(publication) 

clauses 

written_ by(fleming, book(“DR NO”,210)). 
writte n_ by(melville, book(“MOB Y DICK”, 600)). 
long_novel(book(Title,Length)) 

:-written_by(_,book(Title,Length)), Length>300. 


questo aspetto teorico in questo 
momento, serve semplicemente 
ribadire come il Prolog sia un lin¬ 
guaggio nato con solidissime basi 
teoriche e che è in grado di rap¬ 
presentare in forma inferenziale il 
concetto di conoscenza basata su 
fatti e regole. 



dal titolo e dal numero di pagine. 
Si predispongono due predicati: 

written_by che associa l’autore 
alla pubblicazione; la pubblicazio¬ 
ne è una costante formata dalla 
coppia (titolo, pagine). 

Long_novel è il predicato che ri¬ 
sponde alla domanda se esistono, 
e quali sono, i libri classificabili 
come novelle lunghe (romanzi). 

Vediamo nella sezione clauses 
come è programmato il predicato 
long_novel: 

long_novel(book(Title,Length)):~ 
written_by(_, bookfTitle, Length)), 

Length>300. 


Cioè, detto in parole: un roman¬ 
zo è una coppia (titolo, pagine) di 
qualsiasi book la cui lunghezza è 
superiore a 300 pagine. Un criterio 
di classificazione brutale, ma non 
stiamo facendo un corso di biblio¬ 
teconomia :-) 

Interessante il corpo della funzio¬ 
ne/predicato long novel, con l’uso 
del predicato written_by che fa uso 
del “segnaposto (underscore), 
che significa in pratica “non impor¬ 
ta cosa ci sia qui”. 


Un altro sorgente tratto dall’esem¬ 
pio numero 13 presente sul di¬ 
schetto è visibile nel box di questa 
pagina. 



Si tratta di agire su un dominio ti¬ 
pico dell’editoria. Abbiamo dei libri 
caratterizzati dal nome dell’autore, 
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Conclusione 


Esaminando gli esempi a corre¬ 
do del programma, ovviamente il 
manuale e qualche buon libro di 
fondamenti della programmazio¬ 
ne in Prolog, fra l’altro abbondan¬ 
ti in Internet, è abbastanza facile 
impadronirsi dei primi rudimenti e 
soprattutto della sintassi del Turbo 
Prolog. Questa appare a prima vi¬ 
sta inutilmente complicata rispetto 
al Prolog classico, ma evidente¬ 
mente si tratta di prendere confi¬ 
denza con il dialetto specifico. Mol¬ 
to meno facile è invece raggiungere 
un livello produttivo decente con un 
linguaggio di programmazione che 
si discosta e di molto dalla classica 
sequenza di istruzioni. 

Possiamo dire che il Turbo Prolog 
è un prodotto della Borland che tie¬ 
ne fede alla fama dell’azienda ben 
più nota per il Turbo Pascal e suc¬ 


cessivamente per il Delphi sotto 
Windows. Se il Prolog avesse sfon¬ 
dato veramente nel mondo home e 
soprattutto professional, la Borland 
si sarebbe trovata indubbiamente 
in prima linea sul mercato. 

Non è andata così, anche per 
l’obiettiva difficoltà di programmare 
scomponendo un problema in com¬ 
ponenti logiche più che in intervalli 
di tempo, che è il paradigma clas¬ 
sico dei linguaggi sequenziali. 

Oggi il Prolog sopravvive nella 
programmazione logica appan¬ 
naggio dei centri di ricerca nelle 
università, soprattutto inglesi (chis¬ 
sà come mai...), mentre è sparito 
del tutto dalla lista dei compilatori 
di utilizzo corrente sia del program¬ 
matore professionista che dell’hob- 
bista appassionato dell’arte. 

[Tn] 


I tre possibili output della 
compilazione: memoria, 
oggetto o eseguibile. 


Run Compile Edit 


Editor 


Opti ons| 


Fi les 


Setup 



Memory 


domains 

persoli = symbol 
predicates 

parent C person, persoli ) 
clauses 

parent(maria, gesu). 
parent(giuseppe, gesu). 


Compile to: Memory 

-|r(ford, X, Y, C, Z). 

Y=4, C=gray, Z=250O0 
OBJ file n 

EXE file (auto link) rent(A, gesu). 


A=giuseppe 
2 Solutions 





Message 


Load ES001.PRO 
Saoe ES001.PRO 
Compi1ing ESO01.PRO 
parent 


se first letter of option or select uith -> or <- 
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L'intervista 

^ ^nte^st^^A^uech 


Vari personaggi 
e amici incontrati 
qua e ia per una 
chiacchierata sui 
mondo dei retro 
computing. 


Intervista a Alessandro Zuech x 
Jurassic News 

A lessandro lavora come 
IT manager in una socie¬ 
tà multinazionale che ha 
una sede nel nord Italia. Nonostan¬ 
te sia letteralmente immerso nelle 
nuove tecnologie, Alessandro ha 
saputo coltivare la passione per 
l’informatica delle origini dotandosi 
di una ricca collezione e soprattutto 
di una vasta cultura nel settore re¬ 
tro computing. 

JN - Cominciamo con qualche in¬ 
formazione personale per farti co¬ 
noscere meglio dai nostri lettori. 
Dunque ci dicevi che lavori in una 
società nel settore IT e hai iniziato 
a raccogliere materiale retro più o 
meno attorno al 1990... 

AZ - Lavoro in questo settore a 
partire dal 1989, ambiente in cui 
ho svolto per molti anni le attività 
come sistemista. Ricordo con parti¬ 
colare gioia le costanti e importanti 
novità che hanno contraddistinto 
tutti gli anni ‘90: le prime reti, i cam¬ 
biamenti nell’hardware e nei siste¬ 
mi operativi veramente ‘epocali’, la 
scoperta di internet e del mondo 
open source.... 


Tutte cose che hanno lasciato il 
segno e nei ricordi l’indelebile en¬ 
tusiasmo che contraddistigue qual¬ 
siasi attività quando si partecipa a 
realizzare qualcosa di unico. 

JN - La solita domanda: perché e 
come ti è venuta l’idea, poi passio¬ 
ne, di raccogliere i vecchi sistemi di 
calcolo? 

AZ - Il mio rapporto con TIT risulta 
antico, nonostante gli anni non sia¬ 
no ancora tanti. In un certo senso 
sono figlio d’arte, avendo mio pa¬ 
dre lavorato in una grossa azienda 
del settore per più di trent’anni. 

La passione di raccogliere sistemi 
di calcolo nasce molto tempo fa: ri¬ 
cordo quando da bambino accom¬ 
pagnavo qualche volta mio padre 
nei centri di calcolo. I video verdi, il 
rumore delle ventole di questi enor¬ 
mi elaboratori, il silenzio e l’attesa 
religiosa degli operatori quando 
attendevano in merito all’esito di 
qualche riparazione, come se si 
trattasse ogni volta di un’operazio¬ 
ne chirurgica dall’esito incerto. 

Costavano tantissimo, allora, quei 
grossi sistemi e davano relativa¬ 
mente poco rispetto ad ora . ma, 

come oggi del resto, si viveva in un 
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contesto dove spesso veniva 
premiato il valore apparente 
ancor prima di quello reale. 

E facevo domande, le do¬ 
mande che solo i bambini san¬ 
no fare.... una curiosità infinita 
che poi è continuata negli anni 
a venire. 

Dopo essere entrato in pos¬ 
sesso del mio primo ‘vero’ 
home, un vic-20 nel Natale 
1982, un primo timore reven- 
ziale verso il tanto agognato 
computer si è via via trasfor¬ 
mato in un vero hobby. 

JN - Come mai una persona 
che s’interessa delle ultime 
tecnologie e probabimente per 
lavoro e svago possiede gli ul¬ 
timi ritrovati in fatto di telefonini 
e computer mobility, si diverte 
a sporcarsi le mani con sistemi 
pesanti, lenti, limitati e spesso 
anche sporchi nel senso lette¬ 
rale dell’aggettivo? 

AZ - Credo ci sia una forte 
componente di nostalgia per 
quello che tutti allora, senza in¬ 
ternet abbiamo conosciuto. Le 
sgroppate a piedi attraverso la 
mia città per ottenere una ra¬ 
rissima rivista americana piena 
di listati, qualche nuovissima 
cassetta di giochi da copiare li¬ 
tigando innumerevoli volte con 
l’azimuth del registratore.... 

Un sacco di amicizie in più, di 
esperienze condite di emozio¬ 
ne e toccate con mano. 


Qualcosa di diverso e più pro¬ 
fondo rispetto a Facebook e il 
WEB 2.0, ma ogni età ha le 
proprie espressioni. 

Parallelamente mangiavo 
letteralmente le riviste con le 
prove delle nuove scatolette 
che arrivavano da oltreocea¬ 
no, McMicrocomputer in parti¬ 
colare. 

Mi è capitato di aver a che 
fare, recentemente, con qual¬ 
che ex giornalista di quella te¬ 
stata per motivi professionali 
di tutt’altra natura: non vi dico 
l’emozione - neanche tanto 
repressa - quasi avessi a che 
fare con dei premi Nobel (con 
tutto il rispetto per Bo Arnklit, 
uno a cui il premio dovevano 
darlo sul serio). 

Da qui l’interesse per l’har- 
dware, cosa che mi ha porta¬ 
to a cambiare computer ogni 
6-7 mesi. Comprati, smontati, 
provati, venduti tutti o quasi - 
almeno nella fascia di prezzo 
che uno squattrinato studente 
delle medie e superiori si po¬ 
teva permettere: zx81, spec- 
trum, c64, ti99, sega sc3000 
(II), msx, Sinclair ql, amiga, ibm 
PC . 

JN - Parlaci di come hai inizia¬ 
to o ricominciato a raccogliere 
vecchi calcolatori e soprattutto 
perché. 

AZ - Appena entrato nel mon¬ 
do del lavoro, finita di pagare 


l’immancabile automobile a 
rate, ho poi ricominciato a dar 
retta alla mia nostalgia, man 
mano che andavo avanti nello 
studio degli elaboratori moder¬ 
ni e man mano che realizzavo 
di conoscerne, nonostante gli 
sforzi, una parte sempre più 
infinitesimale. 

Erano gli anni delle specializ¬ 
zazioni: l’esperto in hw faceva 
solo le riparazioni, l’esperto 
applicativo era un ragioniere 
convertito all’informatica con 
qualche rudimento di coboI e 
rpg, il sistemista parlava solo 
di reti e di sistemi operativi.... 

Non mi è mai piaciuto (e con¬ 
tinua a non piacermi tutt’ora) ri¬ 
conoscermi in un solo compar¬ 
to, senza visione d’insieme... 

Se oggi studio il pezzo più 
vecchio della mia collezione, 
un sistema/3 IBM a schede 
perforate del 1969 da più di 
una tonnellata di peso, sono 
in grado di seguire il flusso 
dall’input dell’applicazione ge¬ 
stionale che ‘gira’in un preciso 
momento fino al singolo nu¬ 
cleo di memoria a ferrite che 
viene elettricamente orientato 
per determinare la posizione 1 
del singolo bit che viene modi¬ 
ficato. 

Si può fare in un sistema dove 
i singoli transistor sono visibili, 
come i cavi di interconnessio¬ 
ne fra le varie schede, i siste¬ 
mi operativi sono circa 2Kb di 
codice e i manuali riempiono 
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un’intera stanza documentando 
anche la composizione del metallo 
di cui è composto lo chassis.... 

Chiaramente, non che oggi sia 
realmente necessario a qualcuno 
tutto questo in dettaglio.... Quel 
che resta, da allora, è la visione 
fortemente ‘sistemica’ e concreta 
dei problemi da risolvere e la pos¬ 
sibilità di operare su queste pro¬ 
blematiche in team partendo da 
basi di conoscenza comuni e con¬ 
divisibili. 

Un qualcosa che forse oggi in 
questo settore si è perso e che si 
può anche riscoprire rileggendo il 
passato. 

JN - parlaci della tua collezione, 
i pezzi più rari, quelli che ami in 
modo particolare... 

AZ - La mia attuale collezione 
consta in alcuni sistemi IBM, fra cui 
il citato S/3, un series/1 del 1980, 
pc/xt e at oltre ad un as/400. 

Lato microinformatica la parte 
del leone la fa la serie Sinclair che 
è completa, molti Commodore, 
appiè II e mac, un sistema TI99 
completato dalla rara peripheral 
expansion, atari, acorn - il tutto 
completato da molti libri, riviste e 
software di allora. 

JN - Quali sono secondo il tuo 
parere le difficoltà più sfidanti che 
deve affrontare chi vuole dedicarsi 
a questo hobby? 

AZ - Una delle operazioni più diffi¬ 
coltose e che richiedono più tempo 


è oggi quella del recupero del sof¬ 
tware da internet e della successi¬ 
va registrazione su formati origina¬ 
li, floppies o cassette che fossero. 

Un pc da collezione non è com¬ 
pleto se non disponi dell’hardware 
funzionante e dal miglior su/ di al¬ 
lora caricato da una ‘ragliante’ uni¬ 
tà a dischetti . 

JN - Quali sbocchi pubblici può 
avere la tua passione: mostre, fie¬ 
re, musei...? 

AZ - Posso dire di aver scritto, 
non molto tempo fa, un testo finito 
su alcune riviste del settore riguar¬ 
do delle novità prodotto su di un 
Apple Ile dotato di AppleWorks... 
una grande soddisfazione! 

Mi fa molto piacere che in Italia 
siano sempre di più le iniziative 
legate al retrocomputing: iniziati¬ 
ve quali JurassicNews ma anche 
tanti, tanti incontri di appassionati 
di questa e quella retroarchitettura 
che si incontrano ancora una vol¬ 
ta ‘davvero’ e si scambiano pezzi, 
software e informazioni. 

JN - Ci interessa conoscere il tuo 
punto di vista su alcune questioni 
“spinose” che animano il nostro 
mondo e in particolare se ritieni 
possa esistere un futuro per il no¬ 
stro hobby. Un futuro “sostenibile” 
intendiamo, cioè una prospettiva 
di sviluppo che non sia la sempli¬ 
ce collezione privata chiusa in un 
caveau. 
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AZ - Credo che prima o poi po¬ 
trebbe nascere qualcosa di strut¬ 
turato anche da noi, magari lega¬ 
to all’iniziativa di qualche ente e/o 
università. 

Del resto c’è stato un periodo, 
dove dalle parti di Pisa e Ivrea si 
inventavano cose che negli States 
neanche immaginavano! 

Su questo tema attualmente gli 
USA sono al solito al primo posto. 
Sono tante le iniziative e i musei 
dedicati all’IT, soprattutto in Cali¬ 
fornia. 

La capitale del retrocomputing 
risiede oggi senz’altro a Mountain 
View, nel cuore della Silicon Valley. 
Qui risiede il Computer History Mu- 
seum (www.computerhistory.org) 
una iniziativa aperta dove è possi¬ 
bile trovare tutto ciò che conta, da 
alcuni pezzi dell’Eniac ad un PDP- 
1 funzionante, dalla serie completa 
di tutti i micro degli anni ‘80 fino ai 
box con i videogiochi arcade. 


parti un pò più a lungo del solito.... 

JN - Non ti chiediamo se ti piace 
Jurassic News, sarebbe puerile :-). 
Invece vorremmo chiederti in qua¬ 
le direzione migliorativa dovremmo 
lavorare per rendere JN ancora più 
interessante. 

AZ -A mio avviso anche iniziative 
assolutamente encomiabili come 
quella di Jurassic News potrebbe¬ 
ro estendere il proprio range di at¬ 
tività anche all’informatica pre-mi- 
cro, alla fucina di idee e proposte 
rispetto a ciò che è stato e sicura¬ 
mente... sarà. 

[Tn] 


JN - Sappiamo che viaggi all’este¬ 
ro per lavoro. Approfitti di questa 
opportunità per entrare in contatto 
con appassionati di retro calcolo o 
visitare musei o collezioni o fiere, 
oppure in queste occasioni hai il 
tempo troppo limitato? 

AZ - Parlando proprio del Compu¬ 
ter History Museum, sono stato a 
visitarlo alcuni anni or sono e da al¬ 
lora sono diventato socio di questa 
iniziativa che farà in futuro parlare 
sempre più di se. Inutile dire che è 
un mio sogno nel cassetto trovare 
il tempo per trasferirmi da quelle 
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